使用IN子查询时,MSSQL临时表返回所有行

时间:2017-11-16 11:49:09

标签: sql sql-server temp-tables

我最近偶然发现了这个例子。为什么查询在临时表“id”上使用未定义的列时返回所有行。这仅适用于id,它仅在使用IN子查询时有效。

DECLARE @test TABLE
( Id INT)

INSERT INTO @test
SELECT 1 UNION ALL
SELECT 2 UNION ALL
SELECT 3

SELECT * FROM @test

SELECT 1 AS 'myid'
INTO #tmpId

--Returns one rows - OK
SELECT * FROM @test WHERE id in (SELECT myId FROM #tmpId)
--Returns all rowns - WHY
SELECT * FROM @test WHERE id in (SELECT id FROM #tmpId)
--ERROR - no column - OK
SELECT * FROM @test WHERE id in (SELECT asdf FROM #tmpId)
--ERROR - no column - OK
SELECT id FROM #tmpId

DROP TABLE #tmpId

2 个答案:

答案 0 :(得分:2)

当您有多个表时,

始终使用表别名。第一个查询应写为:

Application.Goto Reference:=Sheet1.Range("A1"), Scroll:=True

这就是你想要的。

如果您将第二个查询写为:

SELECT t.* FROM @test t WHERE t.id in (SELECT tt.myid FROM #tmpId tt)

您将收到错误消息。您的版本被解释为相关子查询:

SELECT t.* FROM @test t WHERE t.id in (SELECT tt.id FROM #tmpId tt)

这不是你想要的。它相当于:

SELECT t.* FROM @test t WHERE t.id in (SELECT t.id FROM #tmpId tt)

答案 1 :(得分:1)

在第二个查询中,您将Id列与自身进行比较,因为内部表中不存在,因此始终为true