首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >为什么"SELECT ... WHERE id=1=0“返回除带有id=1的行之外的所有行?

为什么"SELECT ... WHERE id=1=0“返回除带有id=1的行之外的所有行?
EN

Stack Overflow用户
提问于 2019-01-23 20:24:28
回答 2查看 481关注 0票数 8

为什么会出现以下查询:

代码语言:javascript
复制
SELECT * FROM myTable WHERE id=1=0

返回myTable中除具有id=1的行以外的所有行

myTable内容:

代码语言:javascript
复制
+----+-------+
| id | value |
+----+-------+
| 1  | dog   |
| 2  | cat   |
| 3  | parrot|
+----+-------+

现在运行:SELECT * FROM myTable WHERE id=1=0

输出:

代码语言:javascript
复制
+----+-------+
| id | value |
+----+-------+
| 2  | cat   |
| 3  | parrot|
+----+-------+
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-01-23 20:27:45

原因是逻辑应该被评估为:

代码语言:javascript
复制
WHERE (id = 1) = 0

这相当于:

代码语言:javascript
复制
WHERE (id = 1) "is false"

或者:

代码语言:javascript
复制
WHERE id <> 1

尝试运行以下示例:

代码语言:javascript
复制
select 1=1=0, 1=2=3, 1=1=0
票数 9
EN

Stack Overflow用户

发布于 2019-01-23 20:27:08

默认运算符优先级的工作方式如下:

代码语言:javascript
复制
WHERE (ID=1)=0

id=1的情况下,下列哪项结果为假

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

https://stackoverflow.com/questions/54327222

复制
相关文章

相似问题

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