为啥不可以使用delete from---语句删除数据量比较大的表(百万级)中的数据?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了为啥不可以使用delete from---语句删除数据量比较大的表(百万级)中的数据?相关的知识,希望对你有一定的参考价值。

不是不可以使用,而是delete操作会写入日志,导致删除大量数据时性能低下,如果是要清空整表的话,建议用truncate,该操作不记录日志,但无法回滚,删掉后想恢复数据是很麻烦的,所以比较危险,
如果不是删除整表,还是要用delete的。
如果你是想删除大部分数据只留下一小部分的话,可以把那一小部分转移到一个临时的表,然后对原表truncate,再把转移的那部分数据复制回来。
参考技术A 用delete删除会把数据滞留在缓存回滚区,要是删除百万级的数据,这样效率会比较低。建议使用truncate删除,但是前提是这个删除操作不能恢复。 参考技术B 其实也没有什么不可以的。

只是删除数据,在提交前,是要使用回滚段的,这样数据量大的时候,可能将回滚段撑爆。
参考技术C 如何你不想回滚就用truncate速度很快!但删除后数据就不能恢复!
delete 删除比较慢!但删除后数据库可以恢复!後面还是可以加where 条件删除指定数据
参考技术D 没有规定不可以用,只是这种删除,从业务上和效率上要做考究。

用SQL语句怎么删除表中的所有数据?

从一个表中删除数据,使用DELETE语句。从表中删除所有行     

DELETE FROM table_name;

或DELETE * FROM table_name;

或DELETE  FROM  Customers 

WHERE   cust_id =  '10000006';  

DELETE不需要列名和通配符,它是删除整行而不是删除列,要删除指定的列,请使用update语句;并且DELETE语句从表中删除行,甚至是删除表中所有行,而不是删除表本身。

如果想删除表中的所有行,可以使用TRUNCATE TABLE语句,完成相同的工作,而速度更快。

扩展资料

drop直接删掉表。

truncate删除的是表中的数据,再插入数据时自增长的数据id又重新从1开始。

delete删除表中数据,可以在后面添加where字句

(1)DELETE语句执行删除操作的过程是每次从表中删除一行,并且同时将该行的删除操作作为事务记录在日志中保存以便进行进行回滚操作。TRUNCATE TABLE 则一次性地从表中删除所有的数据并不把单独的删除操作记录记入日志保存,删除行是不能恢复的。并且在删除的过程中不会激活与表有关的删除触发器。执行速度快。

(2) 表和索引所占空间。当表被TRUNCATE 后,这个表和索引所占用的空间会恢复到初始大小,而DELETE操作不会减少表或索引所占用的空间。drop语句将表所占用的空间全释放掉。

(3) 一般而言,drop > truncate > delete

(4) 应用范围。TRUNCATE 只能对TABLE;DELETE可以是table和view

(5) TRUNCATE 和DELETE只删除数据,而DROP则删除整个表(结构和数据)。

(6) truncate与不带where的delete :只删除数据,而不删除表的结构(定义)drop语句将删除表的结构被依赖的约束(constrain),触发器(trigger)索引(index);依赖于该表的存储过程/函数将被保留,但其状态会变为:invalid。

参考资料: 百度百科  sql

参考技术A 有两种办法可以删除表中的所有数据:

1、TRUNCATE TABLE 删除表中的所有行,而不记录单个行删除操作。

语法 TRUNCATE TABLE name
参数 name 是要截断的表的名称或要删除其全部行的表的名称。

2、Delete from tablename where 1=1
参考技术B 可以在不删除表的情况下删除所有的行。这意味着表的结构、属性和索引都是完整的:

DELETE FROM table_name

或者:

DELETE * FROM table_name
参考技术C dim sqlstr = "Truncate table 表的名字"
UpdateData(sqlstr)
参考技术D truncate table 表名

以上是关于为啥不可以使用delete from---语句删除数据量比较大的表(百万级)中的数据?的主要内容,如果未能解决你的问题,请参考以下文章

用SQL语句怎么删除表中的所有数据?

用SQL语句怎么删除表中的所有数据?

mysql中删除表记录delete from和truncate table的用法区别

PHP MySQL Delete From 之 Delete

TRUNCATE TABLE 语句中可以带有where字句吗

DB2 误删除了表中的一条数据 使用的语句是 delete from tableA where id =x ;求如何恢复