MySQL语句优化的原则

来源:我想网 时间:2009-10-27 12:09:00 

1、使用索引来更快地遍历表。

缺省情况下建立的索引是非群集索引,但有时它并不是最佳的。在非群集索引下,数据在物理上随机存放在数据页上。

合理的索引设计要建立在对各种查询的分析和预测上。一般来说:

a.有大量重复值、且经常有范围查询( > ,< ,> =,< =)和order by、group by发生的列,可考虑建立群集索引;

b.经常同时存取多列,且每列都含有重复值可考虑建立组合索引;

c.组合索引要尽量使关键查询形成索引覆盖,其前导列一定是使用最频繁的列。索引虽有助于提高性能但不是索引

越多越好,恰好相反过多的索引会导致系统低效。用户在表中每加进一个索引,维护索引集合就要做相应的更新工作。

2、在海量查询时尽量少用格式转换。

3、ORDER BY和GROPU BY使用ORDER BY和GROUP BY短语,任何一种索引都有助于SELECT的性能提高。

4、任何对列的操作都将导致表扫描,它包括数据库函数、计算表达式等等,查询时要尽可能将操作移至等号右边。

5、IN、OR子句常会使用工作表,使索引失效。如果不产生大量重复值,可以考虑把子句拆开。拆开的子句中应该包含索引。

6、只要能满足你的需求,应尽可能使用更小的数据类型:例如使用MEDIUMINT代替INT

7、尽量把所有的列设置为NOT NULL,如果你要保存NULL,手动去设置它,而不是把它设为默认值。

8、尽量少用VARCHAR、TEXT、BLOB类型

9、如果你的数据只有你所知的少量的几个。最好使用ENUM类型

10、正如graymice所讲的那样,建立索引。

标签:mysql,数据库优化,索引
0
投稿

猜你喜欢

  • 深入解析python中的实例方法、类方法和静态方法

    2022-07-23 09:05:57
  • OpenCV哈里斯(Harris)角点检测的实现

    2022-10-07 01:41:26
  • python 递归调用返回None的问题及解决方法

    2022-12-21 05:52:56
  • python2.7 json 转换日期的处理的示例

    2021-02-10 12:39:50
  • asp去除html标记与空格的正则

    2022-12-15 08:40:12
  • js给静态网页代码加密方法

    2007-08-04 19:48:00
  • python+flask编写一个简单的登录接口

    2021-06-09 21:19:02
  • 一个轻量级的XHTML右键菜单[支持IE和firefox]

    2024-04-19 10:58:32
  • Python3 元组tuple入门基础

    2023-01-16 12:13:22
  • Python函数的默认参数设计示例详解

    2021-03-23 04:31:58
  • web标准常见问题集合

    2013-12-25 15:51:19
  • 利用Seaborn绘制20个精美的pairplot图

    2023-08-15 20:09:15
  • 详解Python利用configparser对配置文件进行读写操作

    2022-08-02 22:24:38
  • sqlserver 多表查询不同数据库服务器上的表

    2012-04-13 11:41:51
  • python 日期排序的实例代码

    2023-12-02 16:09:35
  • 记一次python 内存泄漏问题及解决过程

    2021-06-18 17:28:14
  • jquery与google map api结合使用 控件,监听器

    2024-04-25 13:20:53
  • MySQL日志维护策略汇总

    2024-01-26 18:11:53
  • Python迭代器Iterable判断方法解析

    2023-06-11 15:37:19
  • 利用Pytorch实现简单的线性回归算法

    2022-09-08 00:00:09
  • asp之家 网络编程 m.aspxhome.com