码迷,mamicode.com
首页 > 数据库 > 详细

sql中的or的用法说明

时间:2016-05-13 11:40:41      阅读:341      评论:0      收藏:0      [点我收藏+]

标签:

数据库里
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

问题的解决办法是:

用()来改变执行顺序!!!!

sql中的or的用法说明

标签:

原文地址:http://www.cnblogs.com/littlemonk/p/5486472.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!