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

我想用一条delete语句同时删除两张表的信息。表aidaname1test表bidblocal1wh1sh1sz目的:同时从两张表里删除id为1的数据这是我写的sqld... 我想用一条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

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

谢谢。
展开
 我来答
百度网友8e9cc3ca7
推荐于2016-03-14 · TA获得超过185个赞
知道小有建树答主
回答量:899
采纳率:0%
帮助的人:693万
展开全部
如果你是要删除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中测试过,不知道你究竟需要做什么?
jxdclchy1
2007-08-14 · 超过14用户采纳过TA的回答
知道答主
回答量:131
采纳率:0%
帮助的人:0
展开全部
你那样写的是不成立的啊.
这样不就可以了吗?
str=" delete from a where a.ida=1 "
str+="delete from b where b.idb=1 "
兄弟快快吧!
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
gc_ding
2007-08-14 · TA获得超过311个赞
知道小有建树答主
回答量:285
采纳率:0%
帮助的人:265万
展开全部
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)
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
wwjwang
推荐于2018-04-10 · TA获得超过219个赞
知道小有建树答主
回答量:144
采纳率:0%
帮助的人:236万
展开全部
delete (select a.ida as ida from a inner join b on a.ida = b.idb ) where ida = 1
这样试试看
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式