如何使用两列从关系表中删除一行

Posted

技术标签:

【中文标题】如何使用两列从关系表中删除一行【英文标题】:How to delete a row from a relationship table using two columns 【发布时间】:2021-03-31 16:22:21 【问题描述】:

我正在尝试删除表 T1 上的表 T2 和 T3 之间的关系。 我已经搜索过,但只能找到只有一个 INNER JOIN 的 DELETE 示例。

我正在尝试这样的事情,但出现错误:

SQL 错误:ORA-00933。 00000 - “SQL 命令未正确结束”

DELETE t1
FROM T1 t1
INNER JOIN T2 t2
  ON t2.ID = t1.ID_t2
INNER JOIN T3 t3  
  ON t3.ID = t1.ID_t3
  WHERE (t3.property1 IN 'XXX' AND 
        t3.property2 = 1 AND 
        t2.property = 'YYY');

我怎样才能让它工作?

【问题讨论】:

【参考方案1】:

您正在使用 mysql 语法从 Oracle 数据库中删除。 您可以使用EXISTS

DELETE FROM T1 
WHERE EXISTS (SELECT 1 FROM T2 WHERE T2.property = 'YYY' AND T2.ID = T1.ID_t2)
  AND EXISTS (SELECT 1 FROM T3 WHERE T3.property1 = 'XXX' AND T3.property2 = 1 AND T3.ID = T1.ID_t3)

【讨论】:

【参考方案2】:

这不是有效的 Oracle 语法。试试exists:

    DELETE FROM T1 
    where exists 
               (select * from T2 where T2.ID = T1.ID_t2 and T2.property = 'YYY')
    and exists (select * from T3 where T3.ID = T1.ID_t3 and T3.property1 IN ('XXX') AND T3.property2 = 1  ) ;

对于单个值,您可以使用 T3.property1 ='XXX' 而不是 T3.property1 IN ('XXX')

【讨论】:

以上是关于如何使用两列从关系表中删除一行的主要内容,如果未能解决你的问题,请参考以下文章

如何在子查询中使用外部查询中的列从另一个表中获取结果?

如何使用 re.split 在 python 中拆分两列从 CSV 中查找字符串值

如何在不删除sql server表中数据的情况下,让自增的id列从1开始

如何在不删除sql server表中数据的情况下,让自增的id列从1开始

如何使用公共列从多个表中检索数据

怎么删除sql中一整行的数据