首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

drop、truncate和delete的区别

,并且同时将该行的的删除操作记录在redo和undo表空间中以便进行回滚(rollback)和重做操作,但要注意表空间要足够大,需要手动提交(commit)操作才能生效,可以通过rollback撤消操作...delete可根据条件删除表中满足条件的数据,如果不指定where子句,那么删除表中所有记录。 delete语句不影响表所占用的extent,高水线(high watermark)保持原位置不变。...三、drop drop是DDL,会隐式提交,所以,不能回滚,不会触发触发器。 drop语句删除表结构及所有数据,并将表所占用的空间全部释放。...总结: 1、在速度上,一般来说,drop> truncate > delete。 2、在使用drop和truncate时一定要注意,虽然可以恢复,但为了减少麻烦,还是要慎用。...3、如果想删除部分数据用delete,注意带上where子句,回滚段要足够大; 如果想删除表,当然用drop; 如果想保留表而将所有数据删除,如果和事务无关,用truncate即可; 如果和事务有关

57330
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MySQL中drop、delete与truncate的区别

    MySQL中drop、delete与truncate的区别 在MySQL中,drop、delete和truncate是用来删除表中数据或整个表的命令。...虽然它们都有删除数据的功能,但在实际使用中,它们有一些不同的用途和效果。在本文中,我们将讨论这三个命令的区别,以及何时应该使用哪个命令。 1....它的语法如下: TRUNCATE TABLE tablename; TRUNCATE命令与DELETE命令类似,都可以删除表中的数据。然而,它们之间有一些重要的区别。...示例演示 为了更好地理解这三个命令的区别,我们来通过示例演示它们在实际使用中的效果。 假设我们有一个名为"students"的表,它包含了学生的姓名、年龄和成绩。...结论 在MySQL中,DROP、DELETE和TRUNCATE是用于删除表中数据或整个表的命令。

    1.4K20

    MySQL之delete user和drop user 的区别

    MySQL之delete user和drop user 的区别 Tip:在MySQL中,我们经常需要创建用户和删除用户,创建用户时,我们一般使用create user或者grant语句来创建,create...,那么这两种方法有什么区别呢?...mysql.user表中的这两个用户,在去查看用户表,我们发现: mysql 15:20:43>>delete from mysql.user where user='yeyz'; Query OK,...再开看看drop的方法删除用户 首先,我们删除掉刚才的那两个用户,然后使用show grants for语句查看他们的权限: mysql ::>>drop user yeyz@'%'; Query OK...,系统判定这种操作没有权限,直接拒绝了,这就说明使用drop user方法删除用户的时候,会连通db表和权限表一起清除,也就是说删的比较干净,不会对以后的用户产生任何影响。

    1.4K10

    MySQL中drop和delete删用户场景

    关于用户创建的文章,之前写过几篇《MySQL创建用户提示1396》《小白学习MySQL - 不同版本创建用户的些许区别》。 碰巧看到技术社群的这篇文章《同样是删用户,为啥还有差别?》...#'; Query OK, 0 rows affected (0.01 sec) 通过上面的例子发现,第一次创建用户testuser01之后,使用的drop的方式将用户删除,我们重新创建用户,正常创建用户成功...我们知道MySQL的一个新的连接,会为新连接维护一个线程对象,然后从权限数组里查到这个用户的权限,为了获取该用户可完成的权限,还需要将权限值拷贝到这个线程对象中。...回到前面的例子当中,delete操作相当于对这张表删除一条记录,当内存中并未删除,这也就为什么导致了delete操作后,无法重新创建的原因了,而drop操作是将表内记录和内存中的内容一并删除。...如果您认为这篇文章有些帮助,还请不吝点下文章末尾的"点赞"和"在看",或者直接转发pyq,

    22020

    如何恢复oracle中误删除表(drop掉的)?

    恢复表: flashback table test_drop to before drop; 或者: flashback table "BIN$b+XkkO1RS5K10uKo9BfmuA==$0..." to before drop; 注意: 必须9i或10g以上版本支持,flashback无法恢复全文索引 详解: 以下是一个不该发生却经常发生的情况:用户删除了一个非常重要的表 ― 当然是意外地删除...(在某些时候,这个不幸的用户可能就是 DBA!) Oracle9i Database 推出了闪回查询选项的概念,以便检索过去某个时间点的数据,但它不能闪回 DDL 操作,如删除表的操作。...唯一的恢复方法是在另一个数据库中使用表空间的时间点恢复,然后使用导出/导入或其他方法,在当前数据库中重新创建表。...这一过程需要 DBA 进行大量工作并且耗费宝贵的时间,更不用说还要使用另一个数据库进行克隆。

    2.1K20

    如何恢复oracle中误删除表(drop掉的)?

    恢复表: flashback table test_drop to before drop; 或者: flashback table "BIN$b+XkkO1RS5K10uKo9BfmuA==$0"...to before drop; 注意: 必须9i或10g以上版本支持,flashback无法恢复全文索引 详解: 以下是一个不该发生却经常发生的情况:用户删除了一个非常重要的表 ― 当然是意外地删除...(在某些时候,这个不幸的用户可能就是 DBA!) Oracle9i Database 推出了闪回查询选项的概念,以便检索过去某个时间点的数据,但它不能闪回 DDL 操作,如删除表的操作。...唯一的恢复方法是在另一个数据库中使用表空间的时间点恢复,然后使用导出/导入或其他方法,在当前数据库中重新创建表。...这一过程需要 DBA 进行大量工作并且耗费宝贵的时间,更不用说还要使用另一个数据库进行克隆。

    1.6K30

    MySQL数据库:drop、truncate、delete的区别

    1、删除速度:drop>truncate>delete; 2、删除方式: (1)执行delete操作时,每次从表中删除一行,并且同时将该行的的删除操作记录在日志文件中。...(2)truncate通过释放存储表数据所用的页来删除数据,一次性删除表中所有记录,不会将删除的数据记录在日志文件中,只在日志文件中记录页的释放,使用的系统和事务日志资源少,所以执行速度比delete快...(3)drop则删除整个表的结构和数据,但是被依赖的约束、触发器、索引、依赖于该表的存储过程、函数将被保留,但其状态会变为invalid 3、删除后,表和索引所占空间: (1)delete操作不会减少表或索引所占用的空间...(3)drop语句将表所占用的空间全释放掉。...5、使用场景: (1)如果想删除表,当然用drop; (2)如果想保留表而将所有数据删除,而且和事务无关,用truncate即可; (3)如果和事务有关,或者想触发trigger,还是用delete;

    1.3K30

    Rust中move、copy、clone、drop和闭包捕获

    本文中的变量,指的是通过如下代码定义的常量a和变量b。实例指的是绑定到a的i32类型在stack内存的数据,和绑定到b变量的String类型在stack内存和heap内存中的数据。...这是与c++的最大区别,从c++11开始,右值引用的出现,才有了move语义。但rust天生就是move语义。...也就是说Copy和Drop两个trait对同一个类型只能有一个,鱼与熊掌不可兼得。...如果变量没有Drop trait,那就只收回stack内存。 正是由于在Drop::drop方法会做资源清理,所以Copy和Drop trait只能二选一。...("moto", &s); } 最后总结 move、copy、clone、drop和闭包捕获是rust中基本的概念,代码过程中随时要清楚每个变量的变化。

    1.5K10

    面试突击58:truncate、delete和drop的6大区别

    在 MySQL 中,使用 truncate、delete 和 drop 都可以实现表删除,但它们 3 个的使用场景和执行效果完全不同,接下来我们来盘点一下。...truncate、delete、drop区别概述 它们 3 个的区别如下表所示: 区别点 drop truncate delete 执行速度 快 较快 慢 命令分类 DDL(数据定义语言) DDL(数据定义语言...删除条件(where) 不能用 不能用 可使用 回滚 不可回滚 不可回滚 可回滚 自增初始值 - 重置 不重置 接下来我们用案例来演示一下它们的区别。...总结 truncate、drop 和 delete 的区别主要有以下 6 点: 执行速度:drop > truncate > detele。...delete 和 truncate 只删除表数据,而 drop 会删除表数据和表结构以及表的索引、约束和触发器。

    1.4K22

    delete、truncate、drop的区别有哪些,该如何选择

    trigger; 2、在 InnoDB 中,DELETE其实并不会真的把数据删除,mysql 实际上只是给删除的数据打了个标记为已删除,因此 delete 删除表中的数据时,表文件在磁盘上所占空间不会变小...7、delete 操作是一行一行执行删除的,并且同时将该行的的删除操作日志记录在redo和undo表空间中以便进行回滚(rollback)和重做操作,生成的大量日志也会占用磁盘空间。...4、小心使用 truncate,尤其没有备份的时候,如果误删除线上的表,记得及时联系中国民航,订票电话:400-806-9553 3、drop Drop table Tablename 1、drop:...InnoDB 和 MyISAM; drop 语句将删除表的结构被依赖的约束(constrain)、触发器(trigger)、索引(index); 依赖于该表的存储过程/函数将保留,但是变为 invalid...3、小心使用 drop ,要删表跑路的兄弟,请在订票成功后在执行操作!

    42820

    delete、truncate、drop的区别有哪些,该如何选择

    操作语言,只删除数据不删除表的结构,会走事务,执行时会触发trigger; 2、在 InnoDB 中,DELETE其实并不会真的把数据删除,mysql 实际上只是给删除的数据打了个标记为已删除,因此 delete...删除表中的数据时,表文件在磁盘上所占空间不会变小,存储空间不会被释放,只是把删除的数据行设置为不可见。...7、delete 操作是一行一行执行删除的,并且同时将该行的的删除操作日志记录在redo和undo表空间中以便进行回滚(rollback)和重做操作,生成的大量日志也会占用磁盘空间。...4、小心使用 truncate,尤其没有备份的时候,如果误删除线上的表,记得及时联系中国民航,订票电话:400-806-9553 3、drop Drop table Tablename 1、drop:属于数据库...和 MyISAM; drop 语句将删除表的结构被依赖的约束(constrain)、触发器(trigger)、索引(index);  依赖于该表的存储过程/函数将保留,但是变为 invalid 状态。

    45410

    delete、truncate、drop的区别有哪些,该如何选择

    DML操作语言,只删除数据不删除表的结构,会走事务,执行时会触发trigger; 2、在 InnoDB 中,DELETE其实并不会真的把数据删除,mysql 实际上只是给删除的数据打了个标记为已删除,因此...delete 删除表中的数据时,表文件在磁盘上所占空间不会变小,存储空间不会被释放,只是把删除的数据行设置为不可见。...7、delete 操作是一行一行执行删除的,并且同时将该行的的删除操作日志记录在redo和undo表空间中以便进行回滚(rollback)和重做操作,生成的大量日志也会占用磁盘空间。...4、小心使用 truncate,尤其没有备份的时候,如果误删除线上的表,记得及时联系中国民航,订票电话:400-806-9553 3、drop Drop table Tablename 1、drop:...InnoDB 和 MyISAM; drop 语句将删除表的结构被依赖的约束(constrain)、触发器(trigger)、索引(index);  依赖于该表的存储过程/函数将保留,但是变为 invalid

    1.2K00

    【DB笔试面试476】DELETE、DROP和TRUNCATE的区别是什么?

    题目部分 DELETE、DROP和TRUNCATE的区别是什么?...答案部分 DELETE、DROP和TRUNCATE的异同点如下表所示: 表 3-9 DELETE、DROP和TRUNCATE的区别 相同点1、TRUNCATE和不带WHERE子句的DELETE及DROP...,且依赖于该表的存储过程和函数等将变为INVALID状态只删除数据不删除表的定义、约束、触发器和索引SQL命令类型DDL语句,隐式提交,不能对TRUNCATE和DROP使用ROLLBACK命令DML语句...,DROP和TRUNCATE由于是在底层修改了数据字典,所以,无论是大表还是小表执行都非常快,而DELETE是需要读取数据到Undo,所以,对于大表进行DELETE全表操作将会非常慢安全性DROP和TRUNCATE...(7)不能TRUNCATE一个带有ENABLE外键的表,会报错ORA-02266。可以DELETE一个带有ENABLE外键的表。 本文选自《Oracle程序员面试笔试宝典》,作者:李华荣。

    66520

    分享:Eclipse 中 drop to frame 的调试技巧

    前些天和同事交流调试技巧时,知道了 Eclipse debug 时有个 drop to frame 的技巧。这是我以前不知道的,自己又查了一下这个功能的含义。...官方的解释是: Select the Drop to Frame command [ ?...Note this command is only available if the current VM supports drop to frame and the selected stackframe...就是说,这个功能可以重新跳到当前方法的开始处重新执行,并且所有上下文变量的值也回到那个时候。不一定是当前方法,可以点击当前调用栈中的任何一个frame跳到那里(除了最开始的那个frame)。...当然,原来执行过程中产生的副作用是不可逆的(比如你往数据库中插入了一条记录)。 这里也说了如何使用这个功能:http://www.javalobby.org/forums/thread.jspa?

    62920

    delete、truncate、drop的区别有哪些,该如何选择

    DML操作语言,只删除数据不删除表的结构,会走事务,执行时会触发trigger; 2、在 InnoDB 中,DELETE其实并不会真的把数据删除,mysql 实际上只是给删除的数据打了个标记为已删除,因此...delete 删除表中的数据时,表文件在磁盘上所占空间不会变小,存储空间不会被释放,只是把删除的数据行设置为不可见。...7、delete 操作是一行一行执行删除的,并且同时将该行的的删除操作日志记录在redo和undo表空间中以便进行回滚(rollback)和重做操作,生成的大量日志也会占用磁盘空间。...4、小心使用 truncate,尤其没有备份的时候,如果误删除线上的表,记得及时联系中国民航,订票电话:400-806-9553 3、drop Drop table Tablename 1、drop:...InnoDB 和 MyISAM; drop 语句将删除表的结构被依赖的约束(constrain)、触发器(trigger)、索引(index); 依赖于该表的存储过程/函数将保留,但是变为 invalid

    45030

    filter:drop-shadow与box-shadow的区别

    而filter中的drop-shadowIE13才开始支持,移动端Android4.4才开始支持,细想一下,其实离在移动端愉快使用就差一口气,明天的今天,大家说不定就在载歌载舞了。...二、同样的参数值,表现效果有差异 filter中的drop-shadow语法如下: filter: drop-shadow(x偏移, y偏移, 模糊大小, 色值); 例如: filter:drop-shadow...四、drop-shadow不能阴影叠加 box-shadow有个超屌的特性,就是阴影可以任意累加,因此,理论上我们可以使用box-shadow生成任意的图片 但是filter中的drop-shadow就只能抱歉了...五、阴影 vs 盒阴影 实践出真知,下面我们用CSS border写一个虚线框,例如: border: 10px dashed #beceeb; 结果长相如下: 然后,我们分别应用box-shadow和drop-shadow...六、drop-shadow的实际应用 ?

    1.6K10

    HTML5 drag和drop的亲手实践

    因此,这阵子就看了一下网上的一些drag和drog的文章以及W3C的介绍,然后自己亲手实践了一下,毕竟打码,才能变得更强。...首先,先放一个我的demo,大家可以去那里随便拖动一下玩一玩: https://chenjigeng.github.io/example/drag.html 知识储备 与drag和drog有关的属性和事件...node.classList.contains('target')) { return node; } return findTarget(node.parentNode) } 3.为每个div注册一个ondragover事件和ondragleave...function handleDragLeave(ev) { ev.target.classList.remove('dotted') } 4.为每个div注册ondrog事件和ondragend事件...,ondrog事件是重点,它主要是根据被拖动元素和被拖动元素悬挂的那个元素的坐标,来决定是要将被拖动元素插入到悬挂元素的前面还是后面。

    95430
    领券