what is the difference between Delete and Truncate
Answer Posted / soorai ganesh
DELETE is a logged operation on a per row basis. This means that the deletion of each row gets logged and physically deleted.
You can DELETE any row that will not violate a constraint, while leaving the foreign key or any other contraint in place.
TRUNCATE is also a logged operation, but in a different way. TRUNCATE logs the deallocation of the data pages in which the data exists. The deallocation of data pages means that your data rows still actually exist in the data pages, but the extents have been marked as empty for reuse. This is what makes TRUNCATE a faster operation to perform over DELETE.
You cannot TRUNCATE a table that has any foreign key constraints. You will have to remove the contraints, TRUNCATE the table, and reapply the contraints.
TRUNCATE will reset any identity columns to the default seed value. This means if you have a table with an identity column and you have 264 rows with a seed value of 1, your last record will have the value 264 (assuming you started with value 1) in its identity columns. After TRUNCATEing your table, when you insert a new record into the empty table, the identity column will have a value of 1. DELETE will not do this. In the same scenario, if you DELETEd your rows, when inserting a new row into the empty table, the identity column will have a value of 265.
I believe its enough to you...............
| Is This Answer Correct ? | 4 Yes | 0 No |
Post New Answer View All Answers
What is the template in sql?
what is difference between view and Dip.
What are types of storage modes? : sql server analysis services, ssas
how to restart sql server in single user mode? How to start sql server in minimal configuration mode? : Sql server database administration
Are there any preferred steps that need to be taken care of before starting the installation of sql server 2000?
Explain about link server in sql server?
How can you check the version of sql server?
Can we insert data into view sql server?
How can you know if the row fetched from cursor is still valid in underlying table?
How can you insert values in multiple rows using one Insert statement?
What is the difference between clustered index and primary key?
What is used to replicate sessions between instances in coldfusion clusters?
What is the use of RDBMS?
Can you explain what are commit and rollback in sql?
What is partitioned view?