数据库里
a c
0 1
0 2
0 3
1 4
1 5
1 6
这样执行完这语句之后查出来有几条语句?
答案是3条
而我想要的是a为0或1并且c为3的数据显示
应该只有1条的
所以应该这样写
Sql代码 select * from kk where (a='0' or a='1') and c = '3' select * from kk where (a='0' or a='1') and c = '3'
扩展一点:
Sql代码 select * from kk where (a='0' or a='1') or c = '3' select * from kk where (a='0' or a='1') or c = '3'
的结果是什么呢?
答案是显示全部显示,6条
虽然基本,我就犯了没加括号的错误
这样也可以
Sql代码 select * from kk where a in ('0','1') and c = '3' select * from kk where a in ('0','1') and c = '3'
这条执行得到也是1条结果
总结:
where 后面如果有and,or的条件,则or自动会把左右的查询条件分开,即先执行and,再执行or。原因就是:and的执行优先级最高!
关系型运算符优先级高到低为:not and or
问题的解决办法是:
用()来改变执行顺序!!!!