作者tas72732002 (葱头)
看板PHP
标题Fw: [SQL ] 关於 where 前後顺序是否会影响效能
时间Tue May 6 13:35:39 2014
※ [本文转录自 Database 看板 #1JPwsaNg ]
作者: tas72732002 (葱头) 看板: Database
标题: [SQL ] 关於 where 前後顺序是否会影响效能
时间: Mon May 5 23:26:26 2014
资料库名称:MySQL
资料库版本:5.1.33
内容/问题描述:
我想请问一下,假设account是帐号, is_ban(1:代表被锁帐号)
(1) select * from where account='123' and is_ban=0;
(2) select * from where is_ban=0 and account='123';
以上述两句sql,第1句sql是否优於第二句还是一样??
以第1句sql来说资料库运作方式是否是先找出account='123'的rows再找该rows is_ban=0,
还是说先筛选account='123' 再筛选is_ban=0,两个筛选出来的rows再做and??
较常理来说先找account='123'再找is_ban=0会优於先找is_ban再找account='123'吗?
最後题外问个问题 where account='123' and is_ban=0; database换按照sql由左而右的语法进行筛选是嘛?? 也就是先筛选account='123' 再筛选is_ban=0
--
※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 111.249.120.106
※ 文章网址: http://webptt.com/cn.aspx?n=bbs/Database/M.1399303588.A.5EA.html
※ 编辑: tas72732002 (111.249.120.106), 05/05/2014 23:27:43
1F:推 Shiehnpin:记忆中是会受到影响,所以要把严苛的条件放前面 05/06 01:30
※ 发信站: 批踢踢实业坊(ptt.cc)
※ 转录者: tas72732002 (203.69.59.91), 05/06/2014 13:35:39
2F:→ MOONRAKER:有一说绝不要在WHERE最前面写 '1=1 AND' |D 05/06 14:48
3F:推 crossdunk:2的好 05/06 17:58
4F:→ kerash:做合并表搜寻的处理 条件式会有很明显的差别 05/06 20:51