SQL Server 如何清空数据库所有表数据

发布时间:2020-06-17 23:38:25 作者:幻_视
来源:网络 阅读:3263

1、清空SQL Server数据库中所有表数据

(1)编写存储过程脚本:

CREATE PROCEDURE sp_DeleteAllData
AS
EXEC sp_MSForEachTable 'ALTER TABLE ? NOCHECK CONSTRAINT ALL'
EXEC sp_MSForEachTable 'ALTER TABLE ? DISABLE TRIGGER ALL'
EXEC sp_MSForEachTable 'DELETE FROM ?'
EXEC sp_MSForEachTable 'ALTER TABLE ? CHECK CONSTRAINT ALL'
EXEC sp_MSForEachTable 'ALTER TABLE ? ENABLE TRIGGER ALL'
EXEC sp_MSFOREACHTABLE 'SELECT * FROM ?'
GO

说明:

存储过程sp_MSForEachTable :循环检查所有的表(微软官方文档)。

脚本创建了一个命名为sp_DeleteAllData的存储过程,前面两行语句分别禁用约束和触发器,第三条语句才是真正地删除所有数据,接下里的语句分别还原约束和触发器,最后一条语句是显示每个表中的记录,确认是否清空了所有的表数据。

(2)查询出数据库所有表,使用truncate语句逐个删除表数据:

首先使用select语句查询出数据库中所有表名

SELECT name FROM SysObjects Where XType='U' ORDER BY Name

查询到默认当前数据库下面的所有表名,如果需要查询其它数据库下的表,加上Where 条件 name = [dbname]

然后使用truncate或delete语句逐个删除表数据

truncate table order_buyer;

truncate table order_seller;

truncate table receivelist;

...















推荐阅读:
  1. SQL Server中T-SQL查询语句的介绍和使用
  2. 使用达思SQL数据库修复软件导出数据库时的接收数据的数据库如

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

sql server 清空数据库所有表数 ver sql serve

上一篇:好程序员Java学习路线分享JVM类加载机制

下一篇:ASP.NET基于Centos 6.5的跨平台实践

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》