SELECT * FROM tablename WHERE 条件1 AND 条件2 OR 条件1 AND 条件3 OR 条件1;
我想要WHERE后面的条件按顺序来判断,就是 【条件1 AND 条件2】 若不满足就判断 【条件1 AND 条件3】 再不满足就判断 【条件1】;
可是好像是短路效应似的,它会不按顺序来,若最后一个【条件1】满足了,就不会判断前面两个,相当于前面两个白写了。。。请问怎么才能让者三个【xx】按顺序判断呢?
SELECT * FROM tablename WHERE 条件1 AND 条件2 OR 条件1 AND 条件3 OR 条件1;
我想要WHERE后面的条件按顺序来判断,就是 【条件1 AND 条件2】 若不满足就判断 【条件1 AND 条件3】 再不满足就判断 【条件1】;
可是好像是短路效应似的,它会不按顺序来,若最后一个【条件1】满足了,就不会判断前面两个,相当于前面两个白写了。。。请问怎么才能让者三个【xx】按顺序判断呢?
这个问题我验证了一下是存在的,因为sql的where执行顺序是从右到左的,所以就会先判断后面的条件,要是想按自己的顺序执行的话可以把需要先判断的条件放在后面(即右面)。
可以看一下这篇文章里面的:SQL where 条件顺序对性能的影响有哪些 (里面写的挺清楚的)
http://ljh0721.iteye.com/blog/1974161