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