sql server数据库怎样同时删除两张表的数据

两张表有主外键关系,不用存储过程、创建级联删除、触发器就用一条sql语句。请各位指教,谢谢!... 两张表有主外键关系,不用存储过程、创建级联删除、触发器就用一条sql语句。请各位指教,谢谢! 展开
 我来答
很多游戏
高粉答主

2019-11-18 · 游戏精通者,攻略技能点满
很多游戏
采纳数:91 获赞数:386932

向TA提问 私信TA
展开全部

1、打开SQL Server 2008 并连接一个数据库。

2、点击工具栏的“新建查询”按钮,新建一个查询。

3、这个数据库里有个测试表格,里面有7条记录。输入“DELETE * FROM * FROM 测试;”

4、执行“DELETE * FROM * FROM 测试;”软件提示错误。

5、去掉DELETE后面的*号,改为:

DELETE FROM 测试;

执行显示“7行受影响”,也就是之前的7条记录全部被删除了。

6、然后执行SELECT * FROM 测试;查询结果为空,再次验证已删除表格“测试”中的所有记录。

shine戚七七
推荐于2017-10-13 · TA获得超过4.7万个赞
知道大有可为答主
回答量:2万
采纳率:75%
帮助的人:2635万
展开全部
解决办法:
1、在设计数据库表时,通过设置级联删除操作来完成。
2、可以写触发器完成操作。
3、先删除主表的数据行,然后根据关联的外键值来删除附表中的相应行数据即可。

具体方法:
作为外键暂且叫它主表,Delete from Main Where id=@id
则要先删除子表当中 Delete from Detail where MainId = @id
为了保证数据完整性,最好将上面的操作包含在一个事务中,如果两个语句影响的行数都大于零,则提交,否则回滚。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
热情一百
推荐于2017-10-12 · TA获得超过247个赞
知道答主
回答量:62
采纳率:0%
帮助的人:58万
展开全部
主表:Parent,子表:Child,关系:Parent.ID = Child.ParentID
1、同时删除两个表中的所有数据:先子表,再父表,使用外连接(父表可能仍有数据)
DELETE * FROM Child RIGHT JOIN Parent
ON Child.ParentID = Parent.ID;
2、同时删除两个表中符合某个条件的数据:先子表,再父表,使用内连接
DELETE * FROM Child INNER JOIN Parent
ON Child.ParentID = Parent.ID
WHERE 条件子句...;
追问
right 附近存在错误,还有就是delete后面不能出现* 或字段,因为我们删除就是删除一行记录。
追答
@^_^@  有一阵子没有写SQL了!
DELETE 后只能跟一个数据表名,所以上面给出的两个语法都是错误的。
DELETE不能对数据记录集进行操作(如使用子查询返回的结果集),因为一旦涉及两个以上的表,会有级联等问题,单纯的DELETE语句是无法应付这种复杂情况的。
不使用楼主给出的三个条件条,同时删除两个表的数据是比较困难的。
当然,如果写一个函数来处理此事,再用EXECT语句执行该函数,是可以达到要求的,但这除了钻牛角以外,没有太大的意义! 呵呵!到此为止吧。
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
樹葉風
2012-07-24
知道答主
回答量:51
采纳率:0%
帮助的人:17.5万
展开全部
--a_table 主表
--b_table 从表
alter table b_table
add constraint fk_b_table_b字段 foreign key(b字段) references a_table(a字段)
on delete cascade

delete from a_table where 条件
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友6a7d11453
2011-03-19 · TA获得超过954个赞
知道小有建树答主
回答量:931
采纳率:50%
帮助的人:706万
展开全部
为什么非得一条呢 是考试吗 不解
追问
考试中有这样的问题,想知道解决方法。
追答
我觉得应该是考察 两个具有主外键关系的表 需要先删外键表 再删主键表吧
一条语句 确实没用过 一起学习
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 3条折叠回答
收起 更多回答(5)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式