sql脚本中的优先级(and 、or 和 括号)
二月初三辛丑年 牛辛卯月 壬戌日
好多天没更博了,为啥呢,因为我的需求上线了,然后又被bibibi了,其中各种心酸背锅以及瑟瑟发抖。。。天呐
回来继续说,今天一个sql的修改:
需求是这样的:在一个日期范围内(2020-03-01至2021-03-12)查询人员类型为(“1003%”、“1004%”、“1006%”)的数据。
1、我原来错误的写法为:
当我查询出来的数据时间有2015年的,并且查询时间特别特别慢
-- 这段脚本查询出来的数据和时间没有什么关系的
select m.no, m.callDate, m.personType from amain m where m.callDate >= date '202-03-01' and m.callDate< date'2021-03-12' and m.personType LIKE '1003%' or m.personType LIKE '1004%' or m.personType LIKE '1006%' ;
-- 即当出现:
-- condition1 and condition2 OR condition3
-- 其运算实际上是等价于:(condition1 and condition2) or condition3 //先运算and 再运算or
--运算顺序为 and > or
2、正确的写法为:
select m.no, m.callDate, m.personType from amain m where m.callDate >= date '202-03-01' and m.callDate< date'2021-03-12' and (m.personType LIKE '1003%' or m.personType LIKE '1004%' or m.personType LIKE '1006%' );
-- 加入了括号之后就能查出正确的数据了
-- condition1 and (condition2 OR condition3)
-- 其运算实际上先运行了 括号里面的 or 再运行了 括号外的 and
-- 运算顺序为 () > and
综合上述两种情况,就可得到:运算顺序为 () > and >or.
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· Obsidian + DeepSeek:免费 AI 助力你的知识管理,让你的笔记飞起来!
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了