180510.最近踩過和聽過的sql的坑

1. in的巨坑sql

CREATE TABLE #tmp1 (id INT, value int)
CREATE TABLE #tmp2 (id1 INT, value int)
INSERT INTO #tmp1 VALUES  ( 1,1),(2,2),(3,3)
INSERT INTO #tmp2 VALUES  ( 4,1),(5,2),(6,3)
SELECT * FROM #tmp1 WHERE id IN (SELECT id FROM #tmp2)

DROP TABLE #tmp1,#tmp2

#tmp2沒有id這個列,可是 where id in (select id from #tmp2)沒有報錯,並且執行成功。sql廢掉了聯合查詢的關鍵字查找(見下圖),select 那句等同於沒有where過濾。若是是delete,坑死你沒商量。ide

 

2. uniqueidentifier的坑spa

DECLARE @id UNIQUEIDENTIFIER
SET @id = '78DC3F2C-50E3-49FA-B96C-B98CB5D2DE0D select * from #tmp1'
SELECT @id

手動拼接sql時,踩出來的雷。少了一個反單引號。而後,就沒有而後了。後面的邏輯所有做廢。3d

相關文章
相關標籤/搜索