sql语句where后条件执⾏顺序与优化sql语句优化方式
曾经⾯试时。被问到过这个问题。结合⽹上的知识,整理如下:
针对mysql,其条件执⾏顺序是 从左往右,⾃上⽽下;
针对orcale,其条件执⾏顺序是从右往左,⾃下⽽上。
其中mysql:
where执⾏顺序是从左往右执⾏的,在数据量⼩的时候不⽤考虑,但数据量多的时候要考虑条件的先后顺序,此时应遵守⼀个原则:排除越多的条件放在第⼀个。
在⽤MySQL查询数据库的时候,连接了很多个过滤条件,发现⾮常慢。例如:SELECT … WHERE p.languages_id=1 pe=1 AND p.products_id IN (472,474),这样查询需要20多秒,虽然在各个字段上都建⽴了索引。⽤分析Explain SQL⼀分析,发现在第⼀次分析过程中就返回了⼏万条数据:WHERE p.languages_id=1 ,然后再依次根据条件缩⼩范围。
然后稍微改变⼀下WHERE字段的位置之后,速度就有了明显地提⾼:WHERE p.products_id IN (472,474) AND p.languages_id=1 pe=1,这样第⼀次的过滤条件是p.products_id IN (472,474),
它返回的结果只有不到10条,接下来还要根据其它的条件来过滤,⾃然在速度上有了较⼤的提升。经过实践发现,不要以为WHERE中的字段顺序⽆所谓,可以随便放在哪,应该尽可能地第⼀次就过滤掉⼤部分⽆⽤的数据,只返回最⼩范围的数据。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。