惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

酷 壳 – CoolShell
酷 壳 – CoolShell
T
Threatpost
Latest news
Latest news
N
News | PayPal Newsroom
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
Help Net Security
Help Net Security
D
Darknet – Hacking Tools, Hacker News & Cyber Security
AI
AI
Simon Willison's Weblog
Simon Willison's Weblog
TaoSecurity Blog
TaoSecurity Blog
The Last Watchdog
The Last Watchdog
L
LINUX DO - 热门话题
Google DeepMind News
Google DeepMind News
T
Threat Research - Cisco Blogs
O
OpenAI News
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
T
The Exploit Database - CXSecurity.com
NISL@THU
NISL@THU
Application and Cybersecurity Blog
Application and Cybersecurity Blog
S
Securelist
小众软件
小众软件
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
Martin Fowler
Martin Fowler
S
SegmentFault 最新的问题
Cisco Talos Blog
Cisco Talos Blog
云风的 BLOG
云风的 BLOG
AWS News Blog
AWS News Blog
GbyAI
GbyAI
N
News and Events Feed by Topic
cs.CV updates on arXiv.org
cs.CV updates on arXiv.org
美团技术团队
Engineering at Meta
Engineering at Meta
A
About on SuperTechFans
博客园 - 三生石上(FineUI控件)
S
Schneier on Security
博客园 - 聂微东
V2EX - 技术
V2EX - 技术
T
Troy Hunt's Blog
SecWiki News
SecWiki News
S
Secure Thoughts
B
Blog RSS Feed
Hugging Face - Blog
Hugging Face - Blog
WordPress大学
WordPress大学
腾讯CDC
H
Heimdal Security Blog
Exploit-DB.com RSS Feed
Exploit-DB.com RSS Feed
Apple Machine Learning Research
Apple Machine Learning Research
月光博客
月光博客
www.infosecurity-magazine.com
www.infosecurity-magazine.com
P
Privacy International News Feed

博客园 - 最坏是单飞

[转载]启用IIS的Gzip压缩功能 javascript判断IFRAME是否加载完成 - 最坏是单飞 - 博客园 Cookie注入是怎样产生的 判断记录是否存在 exists 和 top 1 要比 count 快 国外网站设计与浏览习惯 CSS中 link与@import的区别 firefox3.0上安装google toolbar的问题 ASP.NET中常用的26个优化性能方法 INSERT 失败,因为下列 SET 选项的设置不正确: 'ARITHABORT' 背英语单词的捷径 提高sql server性能的几种方法 Windows下配置Apache支持PHP windows Server mysql的root密码忘记修复方法 select时尽可能少使用as对性能很有好处 sb.5252.ws恶意注入解决方法 asp调用存储过程返回值为空解决方案 - 最坏是单飞 - 博客园 如何在SQL Sever中建立索引? 解决ASP.NET中Type.GetType方法总返回空的问题 - 最坏是单飞 - 博客园 验证视图状态 MAC 失败
从一个错误提示引出SQL中in和or的问题。
最坏是单飞 · 2008-09-12 · via 博客园 - 最坏是单飞

希望大家帮忙解决下。。

环境是 SQL Server 2000

例子表

create table [table1]

(

      a int identity,

      b int

)

再一次调试SQL语句事有如下查询操作

select [a],[b] from [table1] where [aa] in (1,2,3)

显然, 字段aa是不存在的,所以会报错

服务器: 消息 207,级别 16,状态 3,行 1
列名 'aa' 无效。
服务器: 消息 207,级别 16,状态 1,行 1
列名 'aa' 无效。
服务器: 消息 207,级别 16,状态 1,行 1
列名 'aa' 无效。

然后我觉得很奇怪,就又添加了两个数字

select [a],[b] from [table1] where [aa] in (1,2,3,4,5)

报错信息如下

服务器: 消息 207,级别 16,状态 3,行 1
列名 'aa' 无效。
服务器: 消息 207,级别 16,状态 1,行 1
列名 'aa' 无效。
服务器: 消息 207,级别 16,状态 1,行 1
列名 'aa' 无效。
服务器: 消息 207,级别 16,状态 1,行 1
列名 'aa' 无效。
服务器: 消息 207,级别 16,状态 1,行 1
列名 'aa' 无效。

后来又用同样的数据测试了or的错误信息

 select [a],[b] from [table1] where [aa]=1 or [aa]=1 or [aa]=2 or [aa]=3 or [aa]=4 or [aa]=5)

第一次报错

服务器: 消息 207,级别 16,状态 3,行 1
列名 'aa' 无效。
服务器: 消息 207,级别 16,状态 1,行 1
列名 'aa' 无效。
服务器: 消息 207,级别 16,状态 1,行 1
列名 'aa' 无效。

第二次报错

服务器: 消息 207,级别 16,状态 3,行 1
列名 'aa' 无效。
服务器: 消息 207,级别 16,状态 1,行 1
列名 'aa' 无效。
服务器: 消息 207,级别 16,状态 1,行 1
列名 'aa' 无效。
服务器: 消息 207,级别 16,状态 1,行 1
列名 'aa' 无效。
服务器: 消息 207,级别 16,状态 1,行 1

列名 'aa' 无效。

很不解,为什么in和or所报错误一点不差呢?

而且in为什么不在第一次报错后终止执行?

难道in和or在内部处理时候是一样的?

希望大家讨论下