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

来源:百度知道 编辑:UC知道 时间:2024/06/12 03:24:11
我想用一条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

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

谢谢。

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)

如果你是要删除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中测试过,不知道你究竟需要做什么?

你那样写的是不成立的啊.
这样不就可以了吗?
str=" delete from a where a.ida=1 "
str+="delete from b where b.idb=1 "
兄弟快快吧!

delete (select a.ida as ida from a inner join b on a.ida = b.id