如何一个SQL语句就删除表中所有的数据

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何一个SQL语句就删除表中所有的数据相关的知识,希望对你有一定的参考价值。

用SQL语句一次清空所有数据.找到了三种方法进行清空.使用的数据库为MS SQL SERVER.(表之间不能有外键关系)


1.搜索出所有表名,构造为一条SQL语句


declare @trun_name varchar(8000)
set @trun_name=''
select @trun_name=@trun_name + 'truncate table ' + [name] + ' ' from sysobjects where xtype='U' and status > 0
exec (@trun_name)

该方法适合表不是非常多的情况,否则表数量过多,超过字符串的长度,不能进行完全清理.


2.利用游标清理所有表


declare @trun_name varchar(50)
declare name_cursor cursor for
select 'truncate table ' + name from sysobjects where xtype='U' and status > 0
open name_cursor
fetch next from name_cursor into @trun_name
while @@FETCH_STATUS = 0
begin
  exec (@trun_name)
print 'truncated table ' + @trun_name
fetch next from name_cursor into @trun_name
end
close name_cursor
deallocate name_cursor

这是我自己构造的,可以做为存储过程调用, 能够一次清空所有表的数据,并且还可以进行有选择的清空表.


3.利用微软未公开的存储过程(前提是使用sql server 2005以上版本)


exec sp_msforeachtable "truncate table ?"
--删除当前数据库所有表中的数据sp_MSforeachtable @command1='Delete from ?'sp_MSforeachtable @command1 = "TRUNCATE TABLE ?"


该方法可以一次清空所有表,但不能加过滤条件.


引:csdn,blog.csdn.net/feiji323/article/details/5669775

参考技术A 使用 TRUNCATE TABLE 删除所有行
若要删除表中的所有行,则 TRUNCATE TABLE 语句是一种快速、无日志记录的方法。该语句总是比不带条件的 DELETE 语句要快,因为 DELETE 语句要记录对每行的删除操作,而 TRUNCATE TABLE 语句只记录整个数据页的释放。TRUNCATE TABLE 语句立即释放由该表的数据和索引占用的所有空间。所有索引的分发页也将释放。
与 DELETE 语句相同,使用 TRUNCATE TABLE 清空的表的定义,同其索引和其它相关的对象一起仍保留在数据库中。必须使用 DROP TABLE 语句才能除去表的定义。
TRUNCATE TABLE tablename
----------------------
TRUNCATE TABLE
删除表中的所有行,而不记录单个行删除操作。语法TRUNCATE TABLE name参数name
是要截断的表的名称或要删除其全部行的表的名称。注释TRUNCATE TABLE 在功能上与不带 WHERE 子句的 DELETE 语句相同:二者均删除表中的全部行。但 TRUNCATE TABLE 比 DELETE 速度快,且使用的系统和事务日志资源少。
DELETE 语句每次删除一行,并在事务日志中为所删除的每行记录一项。TRUNCATE TABLE 通过释放存储表数据所用的数据页来删除数据,并且只在事务日志中记录页的释放。
TRUNCATE TABLE 删除表中的所有行,但表结构及其列、约束、索引等保持不变。新行标识所用的计数值重置为该列的种子。如果想保留标识计数值,请改用 DELETE。如果要删除表定义及其数据,请使用 DROP TABLE 语句。
对于由 FOREIGN KEY 约束引用的表,不能使用 TRUNCATE TABLE,而应使用不带 WHERE 子句的 DELETE 语句。由于 TRUNCATE TABLE 不记录在日志中,所以它不能激活触发器。
TRUNCATE TABLE 不能用于参与了索引视图的表。示例下例删除 authors 表中的所有数据。

用SQL语句怎么删除表中的所有数据?

参考技术A

从一个表中删除数据,使用DELETE语句。从表中删除所有行     

DELETE FROM table_name;

或DELETE * FROM table_name;

或DELETE  FROM  Customers 

WHERE   cust_id =  '10000006';  

DELETE不需要列名和通配符,它是删除整行而不是删除列,要删除指定的列,请使用update语句;并且DELETE语句从表中删除行,甚至是删除表中所有行,而不是删除表本身。

如果想删除表中的所有行,可以使用TRUNCATE TABLE语句,完成相同的工作,而速度更快。

扩展资料

drop直接删掉表。

truncate删除的是表中的数据,再插入数据时自增长的数据id又重新从1开始。

delete删除表中数据,可以在后面添加where字句

(1)DELETE语句执行删除操作的过程是每次从表中删除一行,并且同时将该行的删除操作作为事务记录在日志中保存以便进行进行回滚操作。TRUNCATE TABLE 则一次性地从表中删除所有的数据并不把单独的删除操作记录记入日志保存,删除行是不能恢复的。并且在删除的过程中不会激活与表有关的删除触发器。执行速度快。

(2) 表和索引所占空间。当表被TRUNCATE 后,这个表和索引所占用的空间会恢复到初始大小,而DELETE操作不会减少表或索引所占用的空间。drop语句将表所占用的空间全释放掉。

(3) 一般而言,drop > truncate > delete

(4) 应用范围。TRUNCATE 只能对TABLE;DELETE可以是table和view

(5) TRUNCATE 和DELETE只删除数据,而DROP则删除整个表(结构和数据)。

(6) truncate与不带where的delete :只删除数据,而不删除表的结构(定义)drop语句将删除表的结构被依赖的约束(constrain),触发器(trigger)索引(index);依赖于该表的存储过程/函数将被保留,但其状态会变为:invalid。

参考资料: 百度百科  sql

以上是关于如何一个SQL语句就删除表中所有的数据的主要内容,如果未能解决你的问题,请参考以下文章

用SQL语句怎么删除表中的所有数据?

用SQL语句怎么删除表中的所有数据?

如何用SQL语句删除两个表中相同的记录?

sql怎么删除一个表中的所有数据

sql怎么删除一个表中的所有数据

怎样删除mysql一个表中的全部数据