永发信息网

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

答案:5  悬赏:30  手机版
解决时间 2021-03-09 15:22
  • 提问者网友:富士山上尢
  • 2021-03-08 23:18
两张表有主外键关系,不用存储过程、创建级联删除、触发器就用一条sql语句。请各位指教,谢谢!
最佳答案
  • 五星知识达人网友:底特律间谍
  • 2021-03-09 00:14
1、打开SQL Server 2008 并连接一个数据库。



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



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



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



5、去掉DELETe后面的*号,改为:
DELETE FROM 测试;
执行显示“7行受影响”,也就是之前的7条记录全部被删除了。



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

全部回答
  • 1楼网友:几近狂妄
  • 2021-03-09 02:56

这个不是简单的级联删除操作么?跟jsp没关,是数据库的操作~

既然有id了,那么delete from 表2 where 表1.id=表2.id,delete from 表3 where 表1.id=表3.id就行了!

  • 2楼网友:独行浪子会拥风
  • 2021-03-09 02:39
为什么非得一条呢 是考试吗 不解
  • 3楼网友:舊物识亽
  • 2021-03-09 01:51
主表: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 条件子句...;
  • 4楼网友:走死在岁月里
  • 2021-03-09 01:45
解决办法: 1、在设计数据库表时,通过设置级联删除操作来完成。 2、可以写触发器完成操作。 3、先删除主表的数据行,然后根据关联的外键值来删除附表中的相应行数据即可。 具体方法: 作为外键暂且叫它主表,Delete from Main Where id=@id 则要先删除子表当中 Delete from Detail where MainId = @id 为了保证数据完整性,最好将上面的操作包含在一个事务中,如果两个语句影响的行数都大于零,则提交,否则回滚。
我要举报
如以上回答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
点此我要举报以上问答信息
大家都在看
推荐资讯