Sql server 中 两种删除语句的性能差别
2008-12-25 10:38
627 查看
若要删除表中的所有行,则 TRUNCATE TABLE 语句是一种快速、无日志记录的方法。TRUNCATE TABLE 与不含有 WHERE 子句的 DELETE 语句在功能上相同。但是,TRUNCATE TABLE 速度更快,并且使用更少的系统资源和事务日志资源。与 DELETE 语句相比,TRUNCATE TABLE 具有以下优点:所用的事务日志空间较少。
DELETE 语句每次删除一行,并在事务日志中为所删除的每行记录一项。TRUNCATE TABLE 通过释放用于存储表数据的数据页来删除数据,并且在事务日志中只记录页释放。
使用的锁通常较少。
当使用行锁执行 DELETE 语句时,将锁定表中各行以便删除。TRUNCATE TABLE 始终锁定表和页,而不是锁定各行。
如无例外,在表中不会留有任何页。
执行 DELETE 语句后,表仍会包含空页。例如,必须至少使用一个排他 (LCK_M_X) 表锁,才能释放堆中的空表。如果执行删除操作时没有使用表锁,表(堆)中将包含许多空页。对于索引,删除操作会留下一些空页,尽管这些页会通过后台清除进程迅速释放。
与 DELETE 语句相同,使用 TRUNCATE TABLE 清空的表的定义与其索引和其他关联对象一起保留在数据库中。
DELETE 语句每次删除一行,并在事务日志中为所删除的每行记录一项。TRUNCATE TABLE 通过释放用于存储表数据的数据页来删除数据,并且在事务日志中只记录页释放。
使用的锁通常较少。
当使用行锁执行 DELETE 语句时,将锁定表中各行以便删除。TRUNCATE TABLE 始终锁定表和页,而不是锁定各行。
如无例外,在表中不会留有任何页。
执行 DELETE 语句后,表仍会包含空页。例如,必须至少使用一个排他 (LCK_M_X) 表锁,才能释放堆中的空表。如果执行删除操作时没有使用表锁,表(堆)中将包含许多空页。对于索引,删除操作会留下一些空页,尽管这些页会通过后台清除进程迅速释放。
与 DELETE 语句相同,使用 TRUNCATE TABLE 清空的表的定义与其索引和其他关联对象一起保留在数据库中。
相关文章推荐
- sql server 删除索引的语句
- Sql server 删除重复记录的SQL语句保留一条
- sql语句字符串拼接的两种方法 SQL Server
- SQL语句添加删除修改字段[sql server 2000/2005]
- Sql server 删除重复记录的SQL语句
- sql server中查询分析器和设计器性能真的差别很大吗?
- 为什么SQL语句Where 1=1 and在SQL Server中不影响性能
- SQL Server 的 T-SQL 语句的性能评估方法
- SQL SERVER性能分析--死锁检测数据库阻塞语句
- 4 - SQL Server 2008 之 使用SQL语句删除表格
- SQL Server 语句性能测试-转
- 测试SQL Server 语句性能时需要先清空缓存
- SQL server和access两种用SQL语句计算两个日期间隔的年、月以及天数
- sql server和my sql 命令(语句)的差别,sql server与mysql的比較
- sql server性能分析--检测数据库阻塞语句
- 关于两种删除sql server2000中表数据的语法 Truncate与DELETE语句 .
- sql server 性能分析--死锁检测数据库阻塞语句
- 数据库SQL Server性能优化之SQL语句总结
- SQL语句练习实例之十——SQL SERVER 行转列的性能测试
- SQL SERVER中错误delete语句可能误删除所有记录