2021年3月16日星期二

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.

 









原文转载:http://www.shaoqun.com/a/630673.html

跨境电商:https://www.ikjzd.com/

acedota:https://www.ikjzd.com/w/2070

askme:https://www.ikjzd.com/w/2459


二月初三辛丑年牛辛卯月壬戌日好多天没更博了,为啥呢,因为我的需求上线了,然后又被bibibi了,其中各种心酸背锅以及瑟瑟发抖。。。天呐回来继续说,今天一个sql的修改:需求是这样的:在一个日期范围内(2020-03-01至2021-03-12)查询人员类型为("1003%"、"1004%"、"1006%")的数据。1、我原来错误的写法为:当我查询出来的数据时间有2015年的,并且查询时间特别特别慢
tenso:https://www.ikjzd.com/w/1552
writer:https://www.ikjzd.com/w/1280
刘军:https://www.ikjzd.com/w/1835
优1宝贝:https://www.ikjzd.com/w/1507
半年赚22亿!又一华南城大卖要上市:https://www.ikjzd.com/home/138294
全国一亿美元以上大项目逾七百,中国电商再迎新时代!:https://www.ikjzd.com/home/113472

没有评论:

发表评论