当前位置: 首页 > 图文教程 > 数据库 > MYSQL > 优化SQL语句需要注意的4点

MYSQL
MYSQL初学者扫盲
PHP+MYSQL网站开发基础知识
网站主机教程(7):网站主机的数据库技术
PHP基础教程(2):PHP安装
PHP+MySQL教程(1):MYSQL简介
PHP+MySQL教程(2):连接MYSQL数据库
PHP+MySQL教程(3):创建数据库和表
PHP+MySQL教程(4):MySQL Insert Into
PHP+MySQL教程(5):MySQL Select
PHP+MySQL教程(6):MySQL Where子句
PHP+MySQL教程(7):MySQL Order By关键词
PHP+MySQL教程(8):MySQL Update
PHP+MySQL教程(9):MySQL Delete From
PHP+MySQL教程(10):Database ODBC
PHP+AJAX教程(5):AJAX MySQL数据库实例
32位的MySQL数据库迁移到64位的MySQL数据库
MYSQL教程:MYSQL数据值类型(data type)
MYSQL教程:MYSQL列类型(column type)
MYSQL数据库教程:唯一编号
MYSQL教程:MYSQL字符集支持

MYSQL 中的 优化SQL语句需要注意的4点


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2010-01-04   浏览: 95 ::
收藏到网摘: n/a

1.尽量不要对列名进行函数处理。而是针对后面的值进行处理

例如where col1 = -5的效率比where -col1=5的效率要高

因为后面的条件对列值进行了计算。这样的条件下优化器无法使用索引

而是要针对所有值进行计算之后才能再比较

2.尽量使用和数剧列一样的值进行操作

如果col1是数值型

那么例如where col1 = 2和where col1= ‘2′

则前者效率更高

因为比较字符和数值型的时候

引擎需要把两者都转化成双精度然后进行比较

3.减少函数的使用

例如where col1 >= ‘2009-10-26′ and col1 <= ‘2009-10-27′

和where datediff(day,col1,getdate())=0

后者因为用到函数处理。所以col1上的索引又无法使用了

4.尽量不要用OR

一般对于OR的条件

优化器一般会使用全表扫描