GOCHESTER.COM
Search:
 
 
Membership
 
  Member Login
Become a Member
Reset Password
 
     

 
Site Links
 
  Index
News Articles
View Articles By Category
 
     

 
Difference between TRUNCATE, DELETE and DROP (Oracle)
Category: Database related articles
By: Chester Zhang - September 18th, 2009
This article has been read: 137 times.

original article



DELETE


The DELETE command is used to remove rows from a table. A WHERE clause can be used to only remove some rows. If no WHERE condition is specified, all rows will be removed. After performing a DELETE operation you need to COMMIT or ROLLBACK the transaction to make the change permanent or to undo it. Note that this operation will cause all DELETE triggers on the table to fire.


example


SQL> SELECT COUNT(*) FROM emp;
COUNT(*)
----------
14
SQL> DELETE FROM emp WHERE job='SALES';
4 rows deleted.

SQL> COMMIT;
Commit complete.

SQL> SELECT COUNT(*) FROM emp;
COUNT(*)
----------
10


TRUNCATE


TRUNCATE removes all rows from a table. The operation cannot be rolled back and no triggers will be fired. As such, TRUNCATE is faster and doesn't use as much undo space as a DELETE.


example


SQL> TRUNCATE TABLE emp;
Table truncated.

SQL> SELECT COUNT(*) FROM emp;
COUNT(*)
----------
0



DROP


The DROP command removes a table from the database. All the tables' rows, indexes and privileges will also be removed. No DML triggers will fired. The operation cannot be rolled back.


example


SQL> DROP TABLE emp;
Table dropped.



DROP and TRUNCATE are DDL commands, whereas DELETE is a DML command. Therefore DELETE operations can be rolled back (undone), while DROP and TRUNCATE operations cannot be rolled back.




From Oracle 10g a table can be "undropped".


example


SQL> FLASHBACK TABLE emp TO BEFORE DROP;
Flashback complete






Difference between TRUNCATE and DELETE commands


1. TRUNCATE is DDL command whereas DELETE is a DML command.

2. TRUNCATE is much faster than DELETE.

Reason: When you type DELETE. all the data get copied into the Rollback Tablespace first. then delete operation get performed. Thats why when you type ROLLBACK after deleting a table, you can get back the data (The system get it for you from the Rollback Tablespace). All this process take time. But when you type TRUNCATE, it removes data directly without copying it into the Rollback Tablespace. Thats why TRUNCATE is faster. Once you Truncate you cann't get back the data.

3. You cann't rollback in TRUNCATE but in DELETE you can rollback. TRUNCATE removes the record permanently.

4. In case of TRUNCATE, Trigger doesn't get fired. But in DML commands like DELETE. Trigger get fired.

5. You cann't use conditions (WHERE clause) in TRUNCATE. But in DELETE you can write conditions using WHERE clause.







Back to News Articles
View Articles From Database related articles Category