数据库 
首页 > 数据库 > 浏览文章

SQL语句中OR和AND的混合使用的小技巧

(编辑:jimmy 日期: 2024/11/16 浏览:3 次 )

今天有这样得一个需求,如果登陆人是客服的话,会查询订单是'该客服'以及还没有匹配客服的,刚开始想的是直接在sql语句上拼写  or  assigned_id is null  的,测试了一下发现这样的话,前面的其他条件都没有用了

SQL语句中OR和AND的混合使用的小技巧

这样的话,第一个i.server_org_id = 4这个条件已经不适用了,,,,,,,,从这里可以知道AND 的优先级比OR的优先级高,先执行了前面的AND 语句,然后执行后面的OR语句,所以查出来的数据不是我想要的数据

后来又想了一下,可以先将对应的assigned_id查出来,如下

SQL语句中OR和AND的混合使用的小技巧

这样查出来的数据只有assigned_id 为153的

最终版本:

SQL语句中OR和AND的混合使用的小技巧

终于把正确的数据全部读出来了,由此可知,()的优先级比AND 高,先执行(),再执行AND

 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

上一篇:MySQL并发更新数据时的处理方法
下一篇:由不同的索引更新解决MySQL死锁套路
一句话新闻
微软与英特尔等合作伙伴联合定义“AI PC”:键盘需配有Copilot物理按键
几个月来,英特尔、微软、AMD和其它厂商都在共同推动“AI PC”的想法,朝着更多的AI功能迈进。在近日,英特尔在台北举行的开发者活动中,也宣布了关于AI PC加速计划、新的PC开发者计划和独立硬件供应商计划。
在此次发布会上,英特尔还发布了全新的全新的酷睿Ultra Meteor Lake NUC开发套件,以及联合微软等合作伙伴联合定义“AI PC”的定义标准。