首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >地点-行动次序

地点-行动次序
EN

Stack Overflow用户
提问于 2012-11-29 21:32:36
回答 1查看 254关注 0票数 1

关于问题的评论:

不要依赖短路.这些子句可以按Server认为合适的任何顺序进行计算。

就这一答复而言:

代码语言:javascript
运行
复制
SELECT * FROM TABLE WHERE (@vari is null or col = @vari)
  1. 这是正确的吗?
  2. 是否有一个好的测试设置,也许在SQL小提琴中,可以重现这种现象?(这个词用得很松散)
  3. 这种情况只发生在WHERE条款中吗?或者仅仅使用和/或操作符?

我问这个问题是因为我还没有在网上找到任何明确声明这一点的东西。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-11-29 21:35:27

在这里读

http://connect.microsoft.com/SQLServer/feedback/details/537419/sql-server-should-not-raise-illogical-errors

SQLFiddle

样本设置

代码语言:javascript
运行
复制
create table albert(a int NOT NULL,
                        b varchar(23) NOT NULL)
create table stina (a int NOT NULL)
go
insert albert (a, b)
     values (1, '99'),
             (2, 'Gurka'),
             (3, '89')
insert stina (a) values(1), (3), (9), (12)
go

SELECT a.a, a.b + 100
FROM albert a
JOIN stina s ON s.a = a.a
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/13635122

复制
相关文章

相似问题

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