delete: delete from 表
drop: drop table 表 删除整个表结构包括数据 无法恢复
truncate:truncate table 表
-----------------------------------------------------------------------------------
1:TRUNCATE TABLE 在功能上与不带 WHERE 子句的 DELETE 语句相同:二者均删除表中的全部行。
2: TRUNCATE TABLE 比 DELETE 速度快,且使用的系统和事务日志资源少。
3:DELETE 语句每次删除一行,并在事务日志中为所删除的每行记录一项。TRUNCATE TABLE 通过释放存储表数据所用的数据页来删除数据,并且只在事务日志中记录页的释放。
4:TRUNCATE TABLE 删除表中的所有行,但表结构及其列、约束、索引等保持不变。新行标识所用的计数值重置为该列的种子。举例:
使用identity。truncate table 表。之后。再插入的话,标识列的计数值又重1开始。
create table tcc( id int identity primary key, name varchar ) insert into tcc values('a'); insert into tcc values('b'); select *from tcc;
使用delete删除
delete from tcc; insert into tcc values('a'); insert into tcc values('b'); select *from tcc;
结果:identity是从3开始
使用 truncate
5:对于由 FOREIGN KEY 约束引用的表,不能使用 TRUNCATE TABLE,而应使用不带 WHERE 子句的 DELETE 语句。
注意:对于复制表,只能复制表结构或数据,外键约束不能复制,所以可以用truncate 删除,
举例: 熟悉的emp dept表
就可以truncate table dept1;但是不能truncate PL/SQL工具自带的dept表,
6:由于 TRUNCATE TABLE 不记录在日志中,所以它不能激活触发器。 Oracle中不用committ,delete需要,所以truncate后不能恢复数据
TRUNCATE TABLE 不能用于参与了索引视图的表。
7:drop table 表 。删除表全部 ,包括结构数据。
create table dept1 as select *from dept where 1=1;
create table emp1 as select *from emp where 1=1;
truncate table tcc; insert into tcc values('a'); insert into tcc values('b'); select *from tcc;
分享到:
相关推荐
sql之truncate、delete与drop区别
delete,truncate和drop的区别
truncate,delete以及drop区别汇总,需要可以自己下载看看,个人觉得蛮好的!
sql之truncate_、delete与drop区别.pdf sql之truncate_、delete与drop区别.pdf
详细阐述了Oracle中三种删除的方式truncate,drop和delete三者的区别和联系.
truncate,delete,drop的异同点
作为初学者,有时容易混淆truncate,delete,drop之间的根本区别,所有今日小记一下。。。
主要介绍了秒懂drop、truncate和delete的区别,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
SQL语句中----删除表数据drop、truncate和delete的用法,对你爱不完
注意:这里说的delete是指不带where子句的delete语句 相同点 truncate和不带where子句的delete, 以及drop都会删除表内的数据 不同点: 1. truncate和 delete只删除数据不删除表的结构(定义) drop语句将删除表的结构被...
truncate和 delete只删除数据不删除表的结构(定义) drop语句将删除表的结构被依赖的约束(constrain),触发器(trigger),索引(index); 依赖于该表的 存储过程/函数将保留,但是变为invalid状态. 2.delete语句是dml...
本文以一个简单实例为大家介绍了SQL中truncate和delete的区别,帮助大家理解,具体内容如下 ---创建表Table1 IF OBJECT_ID('Table1','U') IS NOT NULL DROP TABLE Table1 GO CREATE TABLE Table1 (ID INT NOT NULL,...
本文主要讲mysql中三种删除表的操作,delete语句、truncate语句以及drop语句的区别: 简介 delete 1、删除整张表的数据: delete from table_name; 2、删除部分数据,添加where子句: delete from table_name ...
您可能感兴趣的文章:数据库中删除语句Drop、Delete、Truncate的相同点和不同点的比较(实例说明)drop,truncate与delete的区别详解MySQL中DROP,TRUNCATE 和DELETE的区别实现mysql从零开始浅析drop user与delete from ...
drop、delete、truncate都表示删除,但是三者有一些差别: Delete用来删除表的全部或者一部分数据行,执行delete之后,用户需要提交(commmit)或者回滚(rollback)来执行删除或者撤销删除。会触发这个表上所有的...
前言 上周同事小姐姐问我:“哈哥你看,我发现...咱们常用的三种删除方式:通过 delete、truncate、drop 关键字进行删除;这三种都可以用来删除数据,但场景不同。 一、从执行速度上来说 drop > truncate >> DELETE 二
主要介绍了SQL删除语句DROP、TRUNCATE、 DELETE 的区别,帮助大家更好的理解和学习sql语句,感兴趣的朋友可以了解下