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

推荐订阅源

Attack and Defense Labs
Attack and Defense Labs
T
Threatpost
C
Cybersecurity and Infrastructure Security Agency CISA
H
Hackread – Cybersecurity News, Data Breaches, AI and More
I
Intezer
C
Cyber Attacks, Cyber Crime and Cyber Security
The Register - Security
The Register - Security
量子位
Security Latest
Security Latest
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
大猫的无限游戏
大猫的无限游戏
小众软件
小众软件
Exploit-DB.com RSS Feed
Exploit-DB.com RSS Feed
C
CXSECURITY Database RSS Feed - CXSecurity.com
MyScale Blog
MyScale Blog
J
Java Code Geeks
Apple Machine Learning Research
Apple Machine Learning Research
Google DeepMind News
Google DeepMind News
WordPress大学
WordPress大学
Spread Privacy
Spread Privacy
Jina AI
Jina AI
博客园 - 【当耐特】
P
Palo Alto Networks Blog
Last Week in AI
Last Week in AI
SecWiki News
SecWiki News
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
cs.AI updates on arXiv.org
cs.AI updates on arXiv.org
G
GRAHAM CLULEY
宝玉的分享
宝玉的分享
Hacker News - Newest:
Hacker News - Newest: "LLM"
T
The Blog of Author Tim Ferriss
V
Vulnerabilities – Threatpost
有赞技术团队
有赞技术团队
T
Tor Project blog
H
Hacker News: Front Page
A
Arctic Wolf
NISL@THU
NISL@THU
A
About on SuperTechFans
云风的 BLOG
云风的 BLOG
Engineering at Meta
Engineering at Meta
V
V2EX
N
News and Events Feed by Topic
Webroot Blog
Webroot Blog
Know Your Adversary
Know Your Adversary
P
Privacy International News Feed
I
InfoQ
D
Docker
L
LINUX DO - 最新话题
K
KPMG report finds enterprise disconnect between AI and its ROI | CIO
U
Unit 42

博客园 - 最坏是单飞

[转载]启用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在内部处理时候是一样的?

希望大家讨论下