oracle:sql:delete_drop_or_truncate
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
oracle:sql:delete_drop_or_truncate [2021/08/08 16:33] – peter | oracle:sql:delete_drop_or_truncate [2021/08/08 17:53] (current) – peter | ||
---|---|---|---|
Line 1: | Line 1: | ||
====== Oracle - SQL - Delete, Drop, or Truncate ====== | ====== Oracle - SQL - Delete, Drop, or Truncate ====== | ||
- | |DELETE|The DELETE command is used to remove rows from a table.| | + | |**DELETE**|The DELETE command is used to remove rows from a table.| |
|:::|A WHERE clause can be used to only remove some rows.| | |:::|A WHERE clause can be used to only remove some rows.| | ||
|:::|If no WHERE condition is specified, all rows will be removed.| | |:::|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.| | |:::|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.| | |:::|Note that this operation will cause all DELETE triggers on the table to fire.| | ||
- | |DROP|The DROP command removes a table from the database.| | + | |**DROP**|The DROP command removes a table from the database.| |
|:::|All the tables' | |:::|All the tables' | ||
|:::|No DML triggers will be fired.| | |:::|No DML triggers will be fired.| | ||
|:::|The operation cannot be rolled back.| | |:::|The operation cannot be rolled back.| | ||
- | |TRUNCATE|TRUNCATE removes all rows from a table.| | + | |**TRUNCATE**|TRUNCATE removes all rows from a table.| |
|:::|The operation cannot be rolled back and no triggers will be fired.| | |:::|The operation cannot be rolled back and no triggers will be fired.| | ||
|::: | |::: | ||
+ | |||
+ | ---- | ||
+ | |||
+ | <WRAP group> | ||
+ | <WRAP half column> | ||
+ | **TRUNCATE** | ||
+ | |||
+ | <code sql> | ||
+ | BEGIN TRAN | ||
+ | TRUNCATE TABLE tranTest | ||
+ | SELECT * FROM tranTest | ||
+ | ROLLBACK | ||
+ | SELECT * FROM tranTest | ||
+ | </ | ||
+ | |||
+ | <WRAP info> | ||
+ | **NOTE: | ||
+ | |||
+ | * Truncate resets identity of table. | ||
+ | * It locks the entire table. | ||
+ | * It is DDL (Data Definition Language). | ||
+ | * The WHERE clause cannot be used with it. | ||
+ | * Trigger is not fired while truncate. | ||
+ | |||
+ | </ | ||
+ | |||
+ | </ | ||
+ | |||
+ | <WRAP half column> | ||
+ | **DELETE** | ||
+ | |||
+ | <code sql> | ||
+ | BEGIN TRAN | ||
+ | DELETE FROM tranTest | ||
+ | SELECT * FROM tranTest | ||
+ | ROLLBACK | ||
+ | SELECT * FROM tranTest | ||
+ | </ | ||
+ | |||
+ | <WRAP info> | ||
+ | **NOTE: | ||
+ | |||
+ | * Delete does not reset identity of table. | ||
+ | * It locks the table row. | ||
+ | * It is DML (Data Manipulation Language), | ||
+ | * The WHERE clause can be used with it to filter data to delete. | ||
+ | * Trigger is fired. | ||
+ | |||
+ | </ | ||
+ | |||
+ | **DELETE with WHERE** | ||
+ | |||
+ | <code sql> | ||
+ | DELETE FROM table_name | ||
+ | WHERE | ||
+ | example_column_id IN (1, | ||
+ | </ | ||
+ | |||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ----- | ||
+ | |||
oracle/sql/delete_drop_or_truncate.1628440424.txt.gz · Last modified: 2021/08/08 16:33 by peter