Difference between TRUNCATE, DELETE and DROP commands
来源:互联网 发布:双翼邮件营销软件 编辑:程序博客网 时间:2024/04/25 12:54
出处:http://www.orafaq.com/faq/difference_between_truncate_delete_and_drop_commands
还有一点区别,truncate会重置自增长的主键,delete不会.
-----------------------------------------------------------------原文分割线-------------------------------------------------------------------------
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.
SQL> SELECT COUNT(*) FROM emp; COUNT(*)---------- 14SQL> DELETE FROM emp WHERE job = 'CLERK';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, TRUCATE is faster and doesn't use as much undo space as a DELETE.
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 be fired. The operation cannot be rolled back.
SQL> DROP TABLE emp;Table dropped.SQL> SELECT * FROM emp;SELECT * FROM emp *ERROR at line 1:ORA-00942: table or view does not exist
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.
PS: DROP and TRUNCATE are DDL commands, whereas DELETE is a DML command. As such, DELETE operations can be rolled back (undone), while DROP and TRUNCATE operations cannot be rolled back.
- Difference between TRUNCATE, DELETE and DROP commands
- Difference between TRUNCATE, DELETE and DROP commands
- truncate drop delete difference
- Oracle-The Main Difference Between DELETE & TRUNCATE
- Difference between Truncate and Delete command in SQL - Interview Questions with Example
- Difference between new (delete) and malloc (free)
- What are the difference between DDL, DML and DCL commands?
- What are the difference between DDL, DML and DCL commands?
- What are the difference between DDL, DML and DCL commands?
- What are the difference between DDL, DML and DCL commands?
- What are the difference between DDL, DML and DCL commands?
- what is the difference between "delete []m_data"and "delete m_data"
- truncate,delete,drop
- delete,truncate,drop 区别
- truncate,drop,delete區別
- truncate,delete,drop 比较
- drop truncate delete区别
- truncate delete drop 区别
- notepad++ 快捷键
- OC报错:framework not found Reveal
- Python中re(正则表达式)模块学习
- 什么样的企业网站更加吸引眼球?
- win8系统安装.NET Framework 3.5
- Difference between TRUNCATE, DELETE and DROP commands
- Linux下/etc/fstab文件详解
- Listener refused the connection with the following error 错误解决
- Android学习笔记(九) android提供的各种对话框
- AFN官网翻译
- 怎么去掉Xcode工程中的某种类型的警告
- Ubuntu下关于tftp的配置
- AFN2.0的使用
- 零基础HTML5游戏制作教程 第2章 简单图形的绘制