我们为什么要关注这个内容?因为很多朋友会一头雾水,或者就是不知道怎么组合使用。今天小编就给大家说说这部分的干货,让大家半分钟看懂。
AND、OR运算符的组合使用
在
WHERE子句中,通过AND、OR运算符可以同时连接多个条件,当然AND、OR运算符也可以同时使用。但是当AND、OR运算符同时存在时,其优先级如何确定呢?与大多数语言一样,SQL语言认为AND运算符的运算级别要高于OR运算符。即当出现
condition1
OR condition2
AND condition3
时,其运算实际上是等价于
condition1
OR (condition2 AND condition3)
因此,
AND、OR运算符需要同时使用时,一定要注意运算符的优先级。
实例
:
同时使用
AND、OR运算符实现查询
如果需要查询所有计算机系和生物系,工资收入(
SAL)超过1000的教师的姓名(TNAME)、系(DNAME)、工资(SAL)信息。如果采用如下SQL代码:
SELECT TNAME, DNAME, SAL
FROM TEACHER
WHERE DNAME='计算机'
OR DNAME='生物'
AND SAL>1000
ORDER BY SAL
很显然没有得到预期的计算结果,这是因为
AND运算符的运算级别要高于OR运算符,代码实际上实现的查询是计算机系的所有教师以及生物系中的工资大于1000的教师的相关信息。要实现例中需要的查询结果,正确的SQL代码为:
SELECT TNAME, DNAME, SAL
FROM TEACHER
WHERE (DNAME='计算机' OR DNAME='生物')
AND SAL>1000
ORDER BY SAL
可以发现,当在
OR运算符连接的两个条件加上括号( )后,得到了需要的查询结果。这是因为,括号( )的优先级高于AND运算符,执行过程就先于AND运算符。
注意
当
OR运算符和AND运算符同时运用时,建议用户不要考虑其默认的优先级顺序,而是采用括号( )来实现需要的执行顺序,这样可以增强程序的可读性。
如需了解更多
python实用知识,点击进入
。
本文为原创文章,版权归知行编程网所有,欢迎分享本文,转载请保留出处!
你可能也喜欢
- ♥ python中的SQLAlchemy是什么?10/09
- ♥ 获取python元组元素的方法有哪些09/11
- ♥ python如何给函数和模块起别名09/12
- ♥ python中条件锁和信号量锁的使用方法12/19
- ♥ python如何将数据保存为txt文件类型08/24
- ♥ python集合是可变的吗?10/21
内容反馈