微软oracle数据库 删除多表相同数据,用一条语句编写,在线等...

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了微软oracle数据库 删除多表相同数据,用一条语句编写,在线等...相关的知识,希望对你有一定的参考价值。

参考技术A 只要在添加外键的时候,增加一个联级删除子句即可实现同时删除两张表的相同数据。alter
table
org_ext
add
constraint
fk_name
foreign
key(p_org_id)
references
p_auth_org
(org_id)
on
delete
cascade

Oracle 多表联合删除?--转

oracle和mysql多表删除数据的方法一大把,好多都是没经过证实的,你很可能已经被错误信息误导了,下面我以mysql两张表删除数据为例,来让给为注意到这一点,我在mysql中新建了两张表,分别是用户表和国家表,如下所示。

用户表users:

技术图片

国家表country,如图:

技术图片

当你看到这两张mysql表的时候,你一定认为多表数据删除的语句是这样的,其实这样是错误的!,如下。

delete from users u,country c where u.id = c.userId and u.id = 20

 

mysql多表删除用上面的语句会报sql syntax语法错误的,报错如下。

[SQL]

delete from users u,country c where u.id = c.userId and u.id = 20

[Err] 1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ‘u,country c where u.id = c.userId and u.id = 20‘ at line 1

mysql多表删除数据正确的方法应该使用内连接来删除,如下两条语句,可任选一句。

//语句一
delete u,c from users u INNER JOIN country c on u.id = c.userId and u.id = 20

//语句二
delete u,c from users u INNER JOIN country c where u.id = c.userId and u.id = 10

 

这个时候你一定会认为,oracle删除多表数据能否用上面这两条语句?答案是:不行!它会报如下错误。

“ORA-00933:SQL命令未正确使用”

说明oracle使用上面的两条语句多表删除数据是不行的,那oracle多表删除数据该怎么写呢?命令如下。

//oracle中只能分开执行
delete from users where users.id = 20
delete from country where country.userId = 20

 

在oracle中不能进行多表关联删除,这可能跟oracle数据库的安全机制有关,你只能把上面的语句分成两条sql语句来执行才可以实现oracle的多表删除。

转自 :http://www.tpyyes.com/a/mysql_oracle/2017/1116/383.html

以上是关于微软oracle数据库 删除多表相同数据,用一条语句编写,在线等...的主要内容,如果未能解决你的问题,请参考以下文章

oracle一对多的表数据查询 ,多表显示对应的最后一条数据

mysql 用一条语句删两张表中的数据

多表级联删除表数据特别慢

oracle用一条sql查出哪些数据不在某个表里

一条sql,有分页,表合并查询,多表连接,用于oracle数据库

用一条SQL(Mysql)语句查询出下表,有2个科目80分以上的人的名字和对应的科目名。