【问题标题】:How to delete rows from one table matching another table?如何从一个表中删除与另一表匹配的行?
【发布时间】:2018-03-18 20:33:06
【问题描述】:

我正在尝试从一个表中删除行。所以这就是我到目前为止所做的。我导入了一个创建临时表的 .CSV 文件。我想删除原始表中与临时表匹配的行。

我尝试了以下代码:

Delete From Table1 
Where postid and userid in (Select postid, userid 
                            from Table2)

但它不起作用。

目标是使用表 2 删除表 1 中的行。

【问题讨论】:

    标签: sql sql-server


    【解决方案1】:

    一个简单的INNER JOIN 就可以完成这项工作:

    DELETE T1
    FROM Table1 T1
    INNER JOIN Table2 T2
    ON T1.postid = T2.postid
    AND T1.userid = T2.userid
    

    【讨论】:

      【解决方案2】:

      这只是另一种有趣的方式:

      DELETE FROM Table1 
      WHERE STR(postid) + STR(userid) 
      IN (SELECT STR(postid) + STR(userid) FROM Table2)
      

      【讨论】:

      • 如果 postiduserid 是 GUID,这在 sql server 中不起作用。不过方法不错。
      【解决方案3】:

      据我了解,您想从 Table1 中删除,您想从 Table2 中创建基于 postid 和 userid 的复合条件,问题是您在 (Select postid,userid from 表 2) 没有返回正确的值以匹配 in 条件,请将查询修改为

      DELETE T1
      FROM Table1 T1
      INNER JOIN Table2 T2
      ON T1.postid = T2.postid
      AND T1.userid = T2.userid
      

      如上一个答案所述

      【讨论】:

        【解决方案4】:

        您可以使用 Merge 语句。在这种情况下,您只对删除感兴趣。在删除部分之后需要一个分号,然后是最后一个分号以结束合并语句。例如:

        MERGE table1 AS target USING table2 AS source
        ON target.postid = source.postid and target.userid = source.userid
        WHEN Matched THEN DELETE;;
        

        一个例子 sqlfiddle:http://sqlfiddle.com/#!18/a932d/1/0

        合并文档:https://docs.microsoft.com/en-us/sql/t-sql/statements/merge-transact-sql

        【讨论】:

          猜你喜欢
          • 2020-09-16
          • 1970-01-01
          • 2021-11-02
          • 2011-03-23
          • 1970-01-01
          • 2021-05-11
          • 1970-01-01
          • 1970-01-01
          • 2011-08-15
          相关资源
          最近更新 更多