【oracle】delete语句同时删除多张表(在线等)

Posted

tags:

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

我想用一条delete语句同时删除两张表的信息。
表a ida name
1 test

表b idb local
1 wh
1 sh
1 sz

目的:同时从两张表里删除id为1的数据
这是我写的sql
delete from a inner join b on a.ida = b.idb where a.ida=1

请各位帮我看看。怎么都不对哦。

谢谢。

如果你是要删除2长表里的数据,可以分步做啊:
delete from a where a.ida=1;
delete from b where b.idb=1;
commit;
像你那种做法,是不可行的,不符合oracle的语法。oracle只允许从一张表中删除数据。你是不是想删除A表中的数据(B表不变),但要这些数据存在于B表中,可以使用:
DELETE FROM a WHERE (a.ida, a.name) IN (SELECT a.ida, a.name FROM a ,b where a.ida=b.idb);
COMMIT;
这些语句我都在oracle92中测试过,不知道你究竟需要做什么?
参考技术A delete from a where a.ida=1
delete from b where b.idb=1

这样要写两句
请描述你的具体要求

如果你的表的ID字段都是有规律的ida,idb,...即id+表名
则可以这样删除所有表的id表名=1的数据

declare @SqlStr varchar(8000)
select @SqlStr=''
select @SqlStr=@SqlStr+'delete from ['+[name]+']'+' where id['+[name]+']=1'+CHAR(10)
from sysobjects where Xtype=N'U'
exec(@SqlStr)
参考技术B delete (select a.ida as ida from a inner join b on a.ida = b.idb ) where ida = 1
这样试试看
参考技术C 你那样写的是不成立的啊.
这样不就可以了吗?
str=" delete from a where a.ida=1 "
str+="delete from b where b.idb=1 "
兄弟快快吧!

oracle 中删除表 drop delete truncate

相同点,使用drop delete truncate 都会删除表中的内容

drop table 表名

delete from 表名(后面不跟where语句,则也删除表中所有的数据)

truncate table 表名

区别

首先delete 属于DML,当不commit时时不生效的

而truncate 和 drop 则是直接生效的,不能回滚。

truncate 和 delete 不删除表的结构,只是针对表中的内容删除

drop语句将删除表的结构,被依赖的约束(constrain),触发器(trigger),索引(index); 依赖于该表的存储过程/函数将保留,但是变为invalid状态.

truncate 会释放占用空间,而drop 和 delete不会。

速度:drop>truncate>dalete

综上所述,可以得到一个问题,使用drop 和 truncate相对delete是危险的,当使用drop 和 truncate 时不能回滚。delete相对安全,可以回滚,并且commit以后才会提交,并且不会删除表结构,也不会释放表所占用的空间。

以上是关于【oracle】delete语句同时删除多张表(在线等)的主要内容,如果未能解决你的问题,请参考以下文章

truncate和delete有啥区别

Oracle下Delete语句

Oracle下Delete语句

truncate和delete之间有啥区别

oracle 中删除表 drop delete truncate

oracle删除表的方式