如何使用两列从关系表中删除一行
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开始