?? 6.1.1 null對in的查詢的影響及解決示例.sql
字號:
--1. NULL 對 IN(NOT IN) 查詢的影響
--測試數據
DECLARE @1 TABLE(col1 int)
INSERT @1 SELECT 1
UNION ALL SELECT NULL
UNION ALL SELECT 2
DECLARE @2 TABLE(col1 int)
INSERT @2 SELECT 1
--查詢
SELECT [@1總記錄數]=COUNT(*) FROM @1
--結果: 3
SELECT [@1在@2表中存在的記錄數]=COUNT(*) FROM @1 a
WHERE col1 IN(SELECT col1 FROM @2)
--結果: 1
SELECT [@1在@2表中存在的記錄數]=COUNT(*) FROM @1 a
WHERE col1 NOT IN(SELECT col1 FROM @2)
--結果: 1
--在@2中插入一條NULL值
INSERT @2 SELECT NULL
SELECT [@1在@2表中存在的記錄數]=COUNT(*) FROM @1 a
WHERE col1 IN(SELECT col1 FROM @2)
--結果: 1
SELECT [@1在@2表中存在的記錄數]=COUNT(*) FROM @1 a
WHERE col1 NOT IN(SELECT col1 FROM @2)
--結果: 0
GO
--2. 使用 EXISTS 代替IN
--測試數據
DECLARE @1 TABLE(col1 int)
INSERT @1 SELECT 1
UNION ALL SELECT NULL
UNION ALL SELECT 2
DECLARE @2 TABLE(col1 int)
INSERT @2 SELECT 1
UNION ALL SELECT NULL
SELECT [@1在@2表中存在的記錄數]=COUNT(*)
FROM @1 a
WHERE EXISTS(SELECT * FROM @2 WHERE col1=a.col1)
--結果: 1
SELECT [@1在@2表中存在的記錄數]=COUNT(*)
FROM @1 a
WHERE NOT EXISTS(SELECT * FROM @2 WHERE col1=a.col1)
--結果: 2
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -