gpt4 book ai didi

sql-server-2008 - 为什么这段 SQL 代码不会产生错误?

转载 作者:行者123 更新时间:2023-12-04 07:00:48 25 4
gpt4 key购买 nike

这个问题在这里已经有了答案:




9年前关闭。




Possible Duplicate:
Column does not exist in the IN clause, but SQL runs



我今天在工作时偶然发现了这个,我想知道,为什么下面的代码没有生成和错误?
CREATE TABLE #TableA (ColumnA VARCHAR(25))
CREATE TABLE #TableB (ColumnB VARCHAR(25))

INSERT INTO #TableA (ColumnA) VALUES('1')
INSERT INTO #TableA (ColumnA) VALUES('2')
INSERT INTO #TableA (ColumnA) VALUES('3')

INSERT INTO #TableB (ColumnB) VALUES('1')

SELECT *
FROM #TableA
WHERE ColumnA IN(SELECT ColumnA FROM #TableB)

输出:
ColumnA
1
2
3

#TableB 上不存在 ColumnA,为什么不生成错误?

@@VERSION 告诉我我正在运行它:
Microsoft SQL Server 2008 (RTM) - 10.0.1600.22 (X64)   Jul  9 2008 14:17:44   Copyright (c) 1988-2008 Microsoft Corporation  Enterprise Edition (64-bit) on Windows NT 6.1 <X64> (Build 7601: Service Pack 1) (VM) 

最佳答案

ColumnA在子查询中 (SELECT ColumnA FROM #TableB)
指的是ColumnA #TableA 是 SELECT 列表中的有效列。

因此没有错误,因为您将 #TableA.ColumnA 与 #TableA.ColumnA 进行比较,所以您会得到三行

如果您想验证上述语句,请将 ColumnA 替换为有效列(例如 ColumnAB)以外的任何内容,您将收到错误消息。

如果你试试这个:

CREATE TABLE #TableA (ColumnA VARCHAR(25))
CREATE TABLE #TableB (ColumnB VARCHAR(25))

INSERT INTO #TableA (ColumnA) VALUES('1')
INSERT INTO #TableA (ColumnA) VALUES('2')
INSERT INTO #TableA (ColumnA) VALUES('3')

INSERT INTO #TableB (ColumnB) VALUES('1')

SELECT *
FROM #TableA
WHERE ColumnA IN(SELECT ColumnAB FROM #TableB)

输出将是

Msg 207, Level 16, State 1, Line 14
Invalid column name 'ColumnAB'.

关于sql-server-2008 - 为什么这段 SQL 代码不会产生错误?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11528612/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com