Difference between DELETE and TRUNCATE
The main difference between TRUNCATE and DELETE lies in their approach to removing data from a database table. While both operations serve to eliminate records, DELETE selectively removes specific rows based on conditions, preserving table structure and constraints. In contrast, TRUNCATE swiftly removes all data from a table, resetting it to an empty state without considering individual rows. This speed advantage comes at the cost of irreversibility and the resetting of identity columns or sequences, making it crucial to choose the appropriate operation based on the desired outcome and database management requirements.
What is a DELETE Command?
DELETE is a DML (Data Manipulation Language) command that is used to delete rows/tuples from a specified table or relation in SQL. Any number of rows can be removed using the DELETE command. It is mostly combined with the WHERE clause to delete some specific rows which satisfy the condition. If the WHERE clause is not added to the query, the DELETE command removes all the rows and empties the table. Delete permissions on the table are required to use this command.
The DELETE statement builds a log file in the transaction log, which indicates it stores the records before deleting them. Hence, in case some important rows of data are removed using the DELETE command, they can be retrieved back using the ROLLBACK command. Since DELETE is a DML command, changes must be manually committed. Therefore, ROLLBACK must be done before COMMIT.
Syntax:
Example Query 1:
Output:
Use the following query to delete all the rows from the student's table.
Output:
Here, all the records are deleted from the table students.
Example Query 2:
Here, only those records are removed from sales where id matches with 2. Hence, merging DELETE and WHERE commands help to filter out the data in SQL.
What is a TRUNCATE Command?
TRUNCATE is a DDL (Data Definition Language) command used to remove complete data from the existing table without modifying or deleting the table structure. WHERE clause cannot be used with TRUNCATE, so we cannot do conditional removal of data from the table using TRUNCATE. Hence, it is better to use it where the entire data of a particular table is to be removed.
Once we delete the data using the TRUNCATE command, the data cannot be retrieved using the ROLLBACK statement. Hence this command must be used carefully as it can lead to the loss of important records. TRUNCATE command deallocates the data pages instead of rows and keeps track of deleted pages in place of rows in transaction logs. This feature of TRUNCATE makes it much faster than DELETE.
Syntax:
Example Query:
Output:
The above statement removed all the records from the sales table in one go.
It's essential to grasp the difference between truncate and delete. While both commands serve the purpose of removing data from a table, they differ significantly in their implications and usage scenarios.
Key differences between DELETE and TRUNCATE
- The DELETE statement removes some or all records from the table, while TRUNCATE deletes entire rows from a table.
- DELETE is a DML command, modifying table data, while TRUNCATE is a DDL command.
- DELETE allows filtering using the WHERE clause, whereas TRUNCATE does not support WHERE clause filtering.
- DELETE triggers all delete triggers on the table, whereas no triggers are activated during TRUNCATE as it doesn't operate on individual rows.
- DELETE performs row-by-row deletion, whereas TRUNCATE operates on data pages, deleting entire table data at once.
- DELETE does not reset table identity, while TRUNCATE resets the identity.
- DELETE requires more locks and database resources due to acquiring locks on each deleted row, while TRUNCATE requires fewer locks by acquiring locks on data pages.
- DELETE makes an entry in the transaction log for each deleted row, while TRUNCATE records transaction logs for each data page.
- TRUNCATE is faster than DELETE as it deallocates data pages instead of rows and records data pages instead of rows in transaction logs.
- Records deleted by TRUNCATE cannot be recovered, whereas data removed by DELETE can be recovered.
- DELETE operations can be part of a transaction and rolled back, while TRUNCATE is auto-committed and cannot be undone.
- DELETE maintains referential integrity by enforcing constraints, whereas TRUNCATE may violate constraints since it removes all data indiscriminately.
- DELETE offers finer control over recovery points, allowing for point-in-time recovery, whereas TRUNCATE lacks this granularity.
- DELETE operations may increase recovery time due to extensive logging, while TRUNCATE speeds up recovery by minimizing logged operations.
- After DELETE, the table retains its original size, but after TRUNCATE, the table size decreases significantly.
DELETE vs TRUNCATE
Let's delve deeper into the difference between truncate and delete to understand their distinct functionalities and implications for database management:
Topic | DELETE | TRUNCATE |
---|---|---|
Definition | DELETE is a SQL command used to remove one or more records using conditions | TRUNCATE is a SQL command used to remove all the records of the table |
Language | DML(Data Manipulation Language) command | DDL(Data Definition Language) command |
Process | It deletes row by row | It deletes all records directly |
Speed | It gets slower with large databases due to its process | It's an instantaneous process |
Requirements | Requires DELETE permission | Requires ALTER permission |
Condition | WHERE clause can be used to get rid of specific records | Can not use the WHERE clause |
Lock | Locks all the records for deletion as a part of its process | Utilizes table lock to lock pages for removal of data |
Log | It logs every record in the transaction log | Just logs the deallocation of the pages where the data was stored |
Commit | COMMIT is done manually | Changes are automatically committed |
Space | Requires more transaction space as it stores for each individual record | Occupies less transaction space as it stores for each page and not for each row |
Retrieval of Data | Data can be retrieved back using the COMMIT or ROLLBACK command | Once the data is gone, it can't be restored |
Conclusion
- DELETE is used for specific record deletion, while TRUNCATE empties the entire table instantly.
- ROLLBACK works with DELETE but not with TRUNCATE.
- TRUNCATE operations are faster than DELETE.
- The difference between TRUNCATE and DELETE extends beyond syntax and speed, notably in transactional behavior and data recovery capabilities.
- Learn more about TRUNCATE & DELETE.