我最近偶然发现了这个例子。为什么查询在临时表“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
答案 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