zoukankan      html  css  js  c++  java
  • 180510.最近踩过和听过的sql的坑

    1. in的巨坑

    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,坑死你没商量。

    2. uniqueidentifier的坑

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

    手动拼接sql时,踩出来的雷。少了一个反单引号。然后,就没有然后了。后面的逻辑全部作废。

  • 相关阅读:
    apns libcurl
    apns libcurl
    epoll
    epoll
    Linux服务器压测
    Linux服务器压测
    libevent
    libevent
    shell脚本
    shell脚本
  • 原文地址:https://www.cnblogs.com/icyJ/p/9018815.html
Copyright © 2011-2022 走看看