`
mamaoyuan625
  • 浏览: 176901 次
  • 性别: Icon_minigender_1
  • 来自: 成都
社区版块
存档分类
最新评论

truncate和delete,drop的区别

阅读更多

 

 

    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;


 

id

name

1

a

2

b

 

使用delete删除

delete from tcc; insert into tcc values('a'); insert into tcc values('b'); select *from tcc;

 

 

结果:identity是从3开始

id

name

3

a

4

b

使用 truncate

 

 

id

name

1

a

2

b

 

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 不能用于参与了索引视图的表。

 

7drop  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; 

 


 

分享到:
评论

相关推荐

    truncate,delete以及drop区别汇总

    ### truncate, delete 以及 drop 区别汇总 #### 一、概述 在数据库管理中,经常需要对数据表进行各种操作,比如删除表中的数据、删除整个表等。`truncate`, `delete` 和 `drop` 是三种常见的 SQL 命令,它们在功能...

    sql之truncate、delete与drop区别

    在SQL语言中,`TRUNCATE`、`DELETE` 和 `DROP` 是三个非常重要的数据操作语句,它们各自有着不同的用途和特性。理解这些差异对于数据库管理至关重要,特别是对于数据安全性和性能优化方面。 首先,`TRUNCATE` 语句...

    delete,truncate和drop的区别

    ### delete,truncate和drop的区别详解 #### 一、概述 在数据库管理中,经常会遇到需要删除数据或表的情况。为了确保数据的准确性和安全性,理解`delete`、`truncate`和`drop`这三个命令的区别至关重要。本文将详细...

    TRUNCATE与 DELETE区别

    在数据库管理中,TRUNCATE 和 DELETE 是两种用于删除数据的方法,它们各有其特定的适用场景和优缺点。本文将详细对比分析这两种操作的区别。 首先,TRUNCATE TABLE 是一种快速删除表中所有数据的方式,它并不记录每...

    sql之truncate_、delete与drop区别.pdf

    在SQL中,`TRUNCATE`、`DELETE`和`DROP`都是用于管理数据库表的重要命令,但它们之间存在显著的区别。本文将深入探讨这三种命令的功能、用法及其应用场景。 #### 相同点 `TRUNCATE`、不带`WHERE`子句的`DELETE`以及...

    详解Truncate delete drop三者的区别

    详细阐述了Oracle中三种删除的方式truncate,drop和delete三者的区别和联系.

    truncate,delete,drop的异同点

    在数据库管理中,`TRUNCATE`, `DELETE`, 和 `DROP` 是三种常见的数据操作语言(DML)与数据定义语言(DDL)命令,它们各自有着不同的用途和特点。接下来,我们将详细探讨这三种命令之间的异同点。 #### 1. 操作对象...

    数据库中truncate,delete,drop语句的比较

    - 相对于`TRUNCATE`和`DELETE`,`DROP`的操作更加强烈,因此在使用时需要格外小心。 - 使用`DROP`之后,与该表相关的所有对象都将变为无效状态。 #### 二、详细对比分析 1. **操作类型**: - `TRUNCATE`:属于...

    秒懂drop、truncate和delete的区别

    `DROP`、`TRUNCATE`和`DELETE`是SQL中用于删除数据的三个关键命令,它们各自有不同的特性和应用场景。以下是它们的详细对比和解释: 1. **DELETE语句**: DELETE是一种数据操纵语言(DML),这意味着它涉及到对...

    drop,truncate与delete的区别

    注意:这里说的delete是指不带where子句的delete语句 相同点 truncate和不带where子句的delete, 以及drop都会删除表内的数据 不同点: 1. truncate和 delete只删除数据不删除表的结构(定义) drop语句将删除表的结构被...

    SQL语句中----删除表数据drop、truncate和delete的用法

    SQL语句中----删除表数据drop、truncate和delete的用法,对你爱不完

    实例理解SQL中truncate和delete的区别

    本文以一个简单实例为大家介绍了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的区别)

    本文主要讲mysql中三种删除表的操作,delete语句、truncate语句以及drop语句的区别: 简介 delete 1、删除整张表的数据: delete from table_name; 2、删除部分数据,添加where子句: delete from table_name ...

    SQL删除语句DROP、TRUNCATE、 DELETE 的区别

    在SQL中,删除数据有三种主要方式:DROP、TRUNCATE和DELETE。这些语句各自有不同的特性和适用场景,理解它们的区别对于有效地管理和维护数据库至关重要。 1. **DROP语句**: - DROP TABLE语句用于彻底删除一个表...

    浅析删除表的几种方法(delete、drop、truncate)

    您可能感兴趣的文章:数据库中删除语句Drop、Delete、Truncate的相同点和不同点的比较(实例说明)drop,truncate与delete的区别详解MySQL中DROP,TRUNCATE 和DELETE的区别实现mysql从零开始浅析drop user与delete from ...

    说一说drop、delete与truncate的区别

    drop、delete、truncate都表示删除,但是三者有一些差别: Delete用来删除表的全部或者一部分数据行,执行delete之后,用户需要提交(commmit)或者回滚(rollback)来执行删除或者撤销删除。会触发这个表上所有的...

Global site tag (gtag.js) - Google Analytics