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