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

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了sql server数据库怎样同时删除两张表的数据相关的知识,希望对你有一定的参考价值。

两张表有主外键关系,不用存储过程、创建级联删除、触发器就用一条sql语句。请各位指教,谢谢!

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

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

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

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

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

DELETE FROM 测试;

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

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

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

具体方法:
作为外键暂且叫它主表,Delete from Main Where id=@id
则要先删除子表当中 Delete from Detail where MainId = @id
为了保证数据完整性,最好将上面的操作包含在一个事务中,如果两个语句影响的行数都大于零,则提交,否则回滚。
参考技术B 主表: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语句执行该函数,是可以达到要求的,但这除了钻牛角以外,没有太大的意义! 呵呵!到此为止吧。

本回答被提问者和网友采纳
参考技术C --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 条件
参考技术D 为什么非得一条呢 是考试吗 不解追问

考试中有这样的问题,想知道解决方法。

追答

我觉得应该是考察 两个具有主外键关系的表 需要先删外键表 再删主键表吧
一条语句 确实没用过 一起学习

SQL Server 触发器事务以及存储过程详解

触发器(trigger)

在使用触发器的同时一般会牵扯到两张表,这两张表只读且是虚拟的表一个是inserted(增加表)另外一个是deleted(删除表)

这两张表的结果总是与被改触发器应用的表的结构相同。当触发器完工后,这两张表就会被删除inseted是存插入和修改的数据,deleted则是存储

删除的的数据

语法:  create  trigger  tgr_name(触发器名称)

             on table_name(表名)

             with encrypion  --加密触发器

             for  update(insert、delete等) 

             as   

           Transact-SQL( 一些SQL语句、类似于下面这这串代码)

--定义变量
declare @password varchar(20),@UserName varchar(20), @temp int,@birthday datetime;
--在 inserted(虚拟表)表中查询已经插入的记录信息
select @password=password,@UserName=UserName,@birthday=Birthday,@temp=Gender from inserted;
-- set @[email protected]+CONVERT(varchar,@password);
--set @[email protected]/2;
insert into SYS_Users(UserName,Password,Gender,Birthday) values(@UserName,@password,@temp,@birthday);
--打印信息提示成功
print 添加用户成功

删除触发器T-SQL语句备份解析

例子:  SYS_Users 表名 .‘U‘指类型表

as
  print 备份数据库中.......;
  if(OBJECT_ID(SYS_Users,U)is not null)
  --存在SYS_Users 表,直接插入数据
  insert into SYS_Users select UserName,[Password],Gender,Birthday,CreateDate,IsDelete from deleted
  else
  --不存在classesBackup创建再插入
   select * into SYS_Users1 from deleted;
   print 备份数据成功!;
insert into SYS_Users select UserName,[Password],Gender,Birthday,CreateDate,IsDelete from deleted
上面这串代码表示在 SYS_Users 插入 deleted 的信息,也就是删除的的数据从而达到了备份的效果
 select * into SYS_Users1 from deleted;
上面这串语句表示 创建一张和deleted数据结构相同的新表,表的名称为 SYS_Users1,并且将deleted里面的数据添加到 SYS_User1表中

 

以上是关于sql server数据库怎样同时删除两张表的数据的主要内容,如果未能解决你的问题,请参考以下文章

sqlserver两张表数据联级删除问题

mysql 删除sql语句

SQL 两张表合并 (两张表的列都相同)

SQL语句:对比两张表的数据并筛选出数据不同的

MySQL如何同时删除主外键关联的两张表中的数据

怎样用Sql语句判断一张表中的两条数据相同