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

2024-11-19 16:53:29
推荐回答(5个)
回答(1):

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

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

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

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

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

DELETE FROM 测试;

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

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

回答(2):

解决办法:
1、在设计数据库表时,通过设置级联删除操作来完成。
2、可以写触发器完成操作。
3、先删除主表的数据行,然后根据关联的外键值来删除附表中的相应行数据即可。

具体方法:
作为外键暂且叫它主表,Delete from Main Where id=@id
则要先删除子表当中 Delete from Detail where MainId = @id
为了保证数据完整性,最好将上面的操作包含在一个事务中,如果两个语句影响的行数都大于零,则提交,否则回滚。

回答(3):

主表: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):

--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 条件

回答(5):

为什么非得一条呢 是考试吗 不解