- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有 2 个带有连接和 where 子句的表。 2 个表的示例内容:
Id FieldA Id FieldB
1 100 1 Yellow
2 100 2 Green
3 200 3 Green
4 200 4 Blue
5 300 5 Yellow
6 300 6 Orange
我正在尝试返回除 fieldA = 200 AND fieldB = Green 以外的所有内容。因此它仍应返回第 2 行,其中包含 fieldA = 100 和 FielDB = Green。但是,这是我的查询,它不起作用。它排除了所有包含 200 和绿色的行:
select t1.FieldA, t2.FieldB
FROM test1 t1
JOIN test2 t2 ON t1.Id = t2.Id
WHERE (t1.FieldA <> 200 AND t2.FieldB <> 'Green')
在我看来,在运行此查询后,唯一排除的行应该是第 3 行,因为它有 fielda = 200 和 fieldb = green,但它只返回第 1 行、第 5 行和第 6 行。在我看来,它应该只在我使用 OR 时这样做。
让我知道哪里出错了,这里有一些 DDL,您可以使用它:
create table dbo.test1
(
Id int not null,
FieldA int
)
create table dbo.test2
(
Id int not null,
FieldB varchar(10)
)
INSERT INTO test1 (Id, FieldA)
VALUES
(1,100),
(2,100),
(3,200),
(4,200),
(5,300),
(6,300)
INSERT INTO test2 (Id, FieldB)
VALUES
(1,'Yellow'),
(2,'Green'),
(3,'Green'),
(4,'Blue'),
(5,'Yellow'),
(6,'Orange')
最佳答案
每个条件都针对整组行进行独立评估。要组合它们,请翻转您的运算符并取反组合,如下所示:
select t1.FieldA, t2.FieldB
FROM test1 t1
JOIN test2 t2 ON t1.Id = t2.Id
WHERE not (t1.FieldA = 200 AND t2.FieldB = 'Green')
您的原始查询基本上是说,首先消除所有 FieldA 不是 200 的行,然后从剩余的行中消除所有 FieldB 不是“绿色”的行。
当您希望这两个条件都适用于给定行时,您首先选择要排除的条件,这就是您从 <>
切换的原因至 =
, 然后让你的 WHERE
子句通过应用 NOT
排除整个事情运营商。
编辑回复:评论
我认为关于您的原始查询返回的结果的混淆以及括号中的条件被“评估为一个”的想法可能源于逻辑否定不是分配的事实,即 A && B
的否定不是 ~A && ~B
,而是 ~(A && B)
.
您描述所需结果的第一句话与查询的正确 t-sql 非常接近。你说“我正在尝试返回除了 fieldA = 200 AND fieldB = Green 之外的所有内容。”句子的最后一部分是您的 where 子句,即
except where fieldA = 200 AND fieldB = Green
用“不”代替“除了”
not where fieldA = 200 AND fieldB = Green
-- or, to make the grouping explicit
not (where fieldA = 200 AND fieldB = Green)
并将其清理为有效的 t-sql 语法
where not (fieldA = 200 AND fieldB = Green)
相比之下,英文相当于WHERE (t1.FieldA <> 200 AND t2.FieldB <> 'Green')
可能是:返回 field1 不是 200 且 field1 不是绿色的所有内容。在这种情况下,匹配 200 或 green 就足以排除该行。
要了解第 2 行和第 4 行被错误排除的原因,请考虑原始 where 子句的真值表:
Field1 <> 200
T F
-----------------
T | T | F |
| | row 4 |
Field2 <> 'Green' -----------------
F | F | F |
| row 2 | |
-----------------
换句话说,第 2 行被排除在外是因为 Field2 = 'Green'
, 使条件 Field2 <> 'Green'
评估为 FALSE
, 所以什么都没有关系 Field1
是,因为 FALSE
任何其他值始终为 FALSE
.
关于SQL Where 子句排除了超出应有的范围,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22617117/
我有一个名为“members”的数据库表。分配给成员的是一个职位。 职位 来自部门。我有 Departments,然后是那些中的 Sub-Departments 和 Sub-Departments 中
我正在尝试为 Solr 搜索应用过滤器标记 Tagging_and_excluding_Filters . 挑战在于同时应用多个标记(对于单个页面上的多个选择选项)。例如 q=mainquery&fq
我知道这个问题已经被问过很多次了,我已经尝试了所有建议,并阅读了有关不同选择器等的所有内容,但没有任何对我有用 给出以下 HTML 片段: link
是否有直接的 LINQ 语法来查找集合 B 中不存在的集合 A 的成员?在 SQL 我会写这个 SELECT A.* FROM A LEFT JOIN B ON A.ID = B.ID WHERE B
我试图排除并在现有xpath中包括以下xpath,但不太确定如何做到这一点 //exclude -> //*[@id="ires"]/ol/li[6]/div/a[1]/img //include
我有 30 个站点,我需要在其中 24 个站点上回显某些内容。我怎样才能排除其他人?该代码不起作用,因为我认为它的逻辑是假的:) $currentsite = get_bloginfo('wpurl'
我需要对目标文件夹进行检查,并检查文件是否来自今天,并且超过5kb 下面的命令根据使用今天的日期存在的文件来提供bool值,但是我还要添加-gt5kb之类的排除项 我尝试使用-Exlcude,但不确定
我编入索引的Elasticsearch文档包含许多字段。我一直在使用match_all查询来获取结果。我想从match_all中排除一些字段,这可能吗? 最佳答案 在Elasticsearch中,您可
我正在为我的 DAO 编写一些测试,因为很多测试使用保存到我的数据库中的测试对象,所以我使用注释 @Before 和 @Before 创建了 setup() 和teardown() 方法@After
我编写了一个程序来解决以下问题: Implement a diffusion limited aggregation simulation on a toroid plane where seeds
这个问题不太可能帮助任何 future 的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况有关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visit
很多时候我必须运行这个查询: select * from users where name is not null and name != '' 有没有更好的方法来做到这一点。我需要更多的性能,任何建
如果检测到某个操作系统,是否有一种简单的方法可以排除某些代码? 我设计了一个运行良好的网站(它是一个 sidescroller),当使用滚轮(向上/向下)时,它会左右滚动。但是,如果您使用的是 Mac
我应该如何排除“IN”子句中的值? $Graduates = "45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,6
很明显,如果一个 Mysql 表的全文索引包含一个出现在 50% 的数据行中的关键字,该关键字将被匹配查询忽略 因此,如果我有一个包含 50 个条目的全文索引“content”的表其中 27 个条目在
我有下面的循环。 我需要提取所有不包含字母 p 的名称 (lskey),但我的尝试不起作用。 for(var i = 0; i "); } } 如果有人能回答,我将不胜感激。 最佳答案 如此接
我正在尝试查找 FTP 服务器上根目录的总大小。但是,我无权访问根目录中的其中一个目录。 我想用这个函数对根目录的大小求和: size = 0 for filename in ftp.nlst("."
我有以下正则表达式来匹配 html 链接: 有点效果。除了不是真的。因为它在 编辑: 这将使它只抓取引号而不是 之后的所有内容 最佳答案 我认为您的正则表达式没有按照您的意愿行事。 这会非贪婪地捕
我在提出异常方面遇到困难,例如: import csv o = open('/home/foo/dummy.csv', 'r') # Empty file! reader = csv.reader(o
关闭。这个问题是not reproducible or was caused by typos .它目前不接受答案。 这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能是on-topi
我是一名优秀的程序员,十分优秀!