度量快速开发平台-专业、快速的软件定制快开平台

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
热搜: 部件 流程 SQL
查看: 1184|回复: 2
打印 上一主题 下一主题

[分享] sql 语句中 and 和or的优先级比较

[复制链接]

348

主题

3572

帖子

9381

积分

论坛元老

Rank: 8Rank: 8

积分
9381
跳转到指定楼层
楼主
发表于 2020-5-2 22:28:15 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
首先,sql语句中not and or的执行优先级从高到低依次为:NOT > AND > OR

例子:
select * from test where condition1 or condition2 and condition3;
其执行效果与下面的sql等价:
select * from test where condition1 or (condition2 and condition3);多个and 和 or 混用也是这个道理,相当于把 and 看成乘号(*), 把 or 看成加号(+),这样sql的执行顺序就一目了然了。

最后还是建议大家严格按照业务逻辑写sql,必要的时候毫不吝啬使用括号,就像上面的情况,如果逻辑是:condition1 且 condition2 或者 condition3,那么请写成:
select * from test where (condition1 and condition2) or condition3;。这样既不会出错,也方便以后查看代码。何乐而不为呢。

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
若現在就覺得失望無力,未來那麽遠妳該怎麽扛...
————————————————————————致自己
回复

使用道具 举报

348

主题

3572

帖子

9381

积分

论坛元老

Rank: 8Rank: 8

积分
9381
沙发
 楼主| 发表于 2020-5-2 22:29:21 | 只看该作者
若現在就覺得失望無力,未來那麽遠妳該怎麽扛...
————————————————————————致自己
回复 支持 反对

使用道具 举报

348

主题

3572

帖子

9381

积分

论坛元老

Rank: 8Rank: 8

积分
9381
板凳
 楼主| 发表于 2020-5-7 22:27:48 | 只看该作者
若現在就覺得失望無力,未來那麽遠妳該怎麽扛...
————————————————————————致自己
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|重庆度量科技  本站关键词:快速开发平台

GMT+8, 2024-12-25 21:29 , Processed in 0.170204 second(s), 24 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表