truncate table和delete table 的区别

truncate table和不带 where 的 detele 功能一样,都是删除表中的所有数据。 但TRUNCATE TABLE 速度更快,占用的日志更少,这是因为 TRUNCATE TABLE 直接释放数据页并且在事务日志中也只记录数据页的释放,而 DELETE 是一行一行地删除,在事务日志中要记录每一条记录的删除。 那么可不可以用 TRUNCATE TABLE 代替不带 WHERE 的 DELETE 呢?在以下情况是不行的: 1、要保留标识的情况下不能用 TRUNCATE TABLE,因为 TRUNCATE TABLE 会重置标识。 2、需要使用触发器的情况下不能使用 TRUNCATE TABLE ,它不会激发触发器。 3、对于由 FOREIGN KEY 约束引用的表(即主键所在的表,不是外键所在的表)不能使用 TRUNCATE TABLE。 4、对于参与了索引视图的表不能使用 TRUNCATE TABLE ,注意指索引视图,并非普通视图。 PS: Truncate是SQL中的一个删除数据表内容的语句,用法是:   TRUNCATE TABLE [Table Name]。 具有聚集索引的视图成为索引视图;必须先为视图创建聚集索引,然后才能为该视图定义其他索引,因为 在创建其他索引的时候,SQL SERVER, 会重建表是的非聚集索引。 转载引用:http://www.cnblogs.com/hanmos/archive/2011/03/28/1997973.html

时间: 2024-10-24 14:05:06

truncate table和delete table 的区别的相关文章

TRUNCATE TABLE 与 DELETE table 区别

语法 TRUNCATE TABLE name;参数  TRUNCATE TABLE 在功能上与不带 WHERE 子句的 DELETE 语句相同:二者均删除表中的全部行. TRUNCATE TABLE 比 DELETE 速度快,且使用的系统和事务日志资源少. 原因: DELETE 语句每次删除一行,并在事务日志中为所删除的每行记录一项. TRUNCATE TABLE 通过释放存储表数据所用的数据页来删除数据,并且只在事务日志中记录页的释放. TRUNCATE TABLE 删除表中的所有行,但表结构

truncate table 和delete * from的区别

区别主要两个 1.   Truncate 是整体删除, delete是逐条删除 2.   truncate不写服务器log,delete写服务器log,这就是为什么truncate要快过delete 所以,影响有:1. truncate 快2. truncate不激活 trigger 3.   truncate 重置 Identity

【MySQL】 empty table and delete table.

1.MySQL生成删除满足条件的表的sql: 1 SELECT 2 CONCAT( 3 'DROP TABLE ', 4 GROUP_CONCAT(table_name), 5 ';' 6 ) AS statement 7 FROM 8 information_schema.TABLES 9 WHERE 10 table_schema = 'testmybatis' 11 AND table_name LIKE 'table_mo_%'; DROP TABLE table_mo_tt1,tabl

【SqlServer】empty table and delete table and create table

1.建表 1 IF object_id (N'表名', N'U') IS NULL CREATE TABLE 表名 ( 2 id INT IDENTITY (1, 1) PRIMARY KEY ,......); 2.查询所有满足条件的表 1 SELECT 2 NAME 3 FROM 4 sys.objects 5 WHERE 6 type = 'u' 7 AND NAME LIKE 'test_%'; 3.批量删除满足条件的表 1 DECLARE 2 @NAME VARCHAR (50) 3

Truncate table、Delete与Drop table的区别

Truncate table.Delete与Drop table的区别 TRUNCATE TABLE 在功能上与不带 WHERE 子句的 DELETE 语句相同:二者均删除表中的全部行.但 TRUNCATE TABLE 比 DELETE 速度快,且使用的系统和事务日志资源少. DELETE 语句每次删除一行,并在事务日志中为所删除的每行记录一项.TRUNCATE TABLE 通过释放存储表数据所用的数据页来删除数据,并且只在事务日志中记录页的释放. TRUNCATE TABLE 删除表中的所有行

truncate table与delete区别

truncate table需要drop table权限,它是完全清空一张表. 从逻辑上看,truncate table同delete 一样,或是drop table +create table一样.使用truncate table删除全表数据,要比delete要快.使用truncate table清空数据,不能进行回滚,且不受表间外键约束限制. truncate是DDL语句,而且delete是DML语句,两者区别如下: 1.truncate 是邮drop table+create table

SQL中truncate table和delete的区别

TRUNCATE TABLE 在功能上与不带 Where 子句的 Delete 语句相同:二者均删除表中的全部行.但 TRUNCATE TABLE 比 Delete 速度快,且使用的系统和事务日志资源少. Delete 语句每次删除一行,并在事务日志中为所删除的每行记录一项.TRUNCATE TABLE 通过释放存储表数据所用的数据页来删除数据,并且只在事务日志中记录页的释放. TRUNCATE TABLE 删除表中的所有行,但表结构及其列.约束.索引等保持不变.新行标识所用的计数值重置为该列的

truncate table 和delete

delete table 和 truncate table 使用delete语句删除数据的一般语法格式: delete [from] {table_name.view_name} [where<search_condition>] 将XS表中的所有行数据删除 delete XS 执行完后,发现XS表中的数据都删除了,但是表的结构什么都还在. truncate truncate table语句将删除指定表中所有数据,因此也称其为清除表数据语句,一般格式如下 truncate table name

delete,truncate 和 delete之间的区别

1.首先看下语法定义: drop table_name truncate table_name delete table_name [where column_name = value] 2.各个删除操作删除的内容: drop:删除内容和定义,释放空间.简单来说就是把整个表去掉.以后要新增数据是不可能的,除非新增一个表 例如:一个班就是一个表,学生就是表中的数据,学生的职务就是定义 drop table class,就是把整个班移除.学生和职务都消失 比如下面TestSchool数据库中有两张表