Difference for Delete TABLE and Truncate TABLE
Delete TABLE VS Truncate TABLE
In order to remove all data from one table, you may use delete or truncate command. Just like
Syntax
Truncate [TABLE] table_name;
Delete [LOW_PRIORITY] [QUICK] [IGNORE] FROM table_name
[ WHERE where_condition]
[ORDER By .....]
[LIMIT row_count]
Syntax
Truncate [TABLE] table_name;
Delete [LOW_PRIORITY] [QUICK] [IGNORE] FROM table_name
[ WHERE where_condition]
[ORDER By .....]
[LIMIT row_count]
e.g.
Delete FROM table_name;
Delete FROM table_name;
Truncate FROM table_name;
But there are some difference for them.
1. Speed
Truncate is faster than Delete.
Truncate will drop table and create a new table for you. Delete will just remove all data, but not table.
2. Return Value
Truncate will return 0 because it remove the table
Delete will return the number of removed rows.
3. Increment primary key (MyISAM Table)
Truncate will clear the increment key to 1.
Delete will not influence the increment key.
E.g. If the last increment key was 1000, the next inserted record key after Delete will be set to 10001, on the contrary, the new key after Truncate will be set to 1.
4. Remove parts of records or Where Clause
Truncate will all data
Delete can remove parts of records based on Where clause.
E.g. Delete FROM table_name WHERE id BETWEEN 100 AND 1000;
5. Language
Truncate is DDL (Data Definition Language).
Delete is DML (Data Manipulation Language).
6. Restore data
you nay use rollback to restore data after you execute Delete command
You can not restore the data after you execute Truncate command
5. Language
Truncate is DDL (Data Definition Language).
Delete is DML (Data Manipulation Language).
6. Restore data
you nay use rollback to restore data after you execute Delete command
You can not restore the data after you execute Truncate command
All data will be lost permanently after you execute truncate or delete clause. So, please remember to check all data before you remove all data.
No comments:
Post a Comment