首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQL处理顺序

SQL处理顺序
EN

Stack Overflow用户
提问于 2017-01-19 16:58:40
回答 2查看 99关注 0票数 2

假设我有一个查询

代码语言:javascript
复制
select * from A
Except 
select * from B 
union all
select * from B 
except
select * from A

查询处理方式如下

代码语言:javascript
复制
select * 
from 
(
select * from A
Except 
select * from B 
) a
union all
(
select * from B
Except 
select * from A 
) b

如何在sql中定义处理顺序。它在任何情况下都会像这样处理吗?

代码语言:javascript
复制
select * from A
Except 
select * from
(
select * from B 
union all
select * from B 
) a
except
select * from A
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2017-01-19 17:08:52

UNIONEXCEPT具有相等的优先级,但它们将从左到右绑定,这意味着它们在处理时按照“从左到右”的顺序进行计算。

来自@SeanLange的URL (TL;DR),值得注意:

如果在表达式中与其他运算符一起使用(除外)交叉,则在以下优先级的上下文中对其进行计算:

  • 括号中的表达式
  • 相交算子
  • 除外,联合是根据它们在表达式中的位置从左到右计算的
票数 3
EN

Stack Overflow用户

发布于 2017-01-19 17:07:36

除了和UNION被处理为“从左到右”。这意味着不使用任何括号来确定它们将按照它们在sql中出现的顺序进行处理。

https://msdn.microsoft.com/en-us/library/ms188055.aspx

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41747501

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档