×

truncate delete run

truncate(数据库表的删除方式有drop、delete和truncate各有什么特点)

admin admin 发表于2022-09-04 20:52:21 浏览156 评论0

抢沙发发表评论

本文目录

数据库表的删除方式有drop、delete和truncate各有什么特点


意义是不一样的,drop是删除表,使用drop之后表结构和表的数据都会被删除,truncate 和 delete是删除表里的数据,但不删除表本身,truncate 和 delete相比,truncate要快很多,但缺点就是不能回滚,包括索引等都会变成初始值,数据就无法恢复了。

truncate和drop有什么区别啊


SQL truncate 、delete与drop区别
相同点:
1.truncate和不带where子句的delete、以及drop都会删除表内的数据。
 
2.drop、truncate都是DDL语句(数据定义语言),执行后会自动提交。
 
不同点:
1. truncate 和 delete 只删除数据不删除表的结构(定义)
drop 语句将删除表的结构被依赖的约束(constrain)、触发器(trigger)、索引(index);依赖于该表的存储过程/函数将保留,但是变为 invalid 状态。
 
2. delete 语句是数据库操作语言(dml),这个操作会放到 rollback segement 中,事务提交之后才生效;如果有相应的 trigger,执行的时候将被触发。
truncate、drop 是数据库定义语言(ddl),操作立即生效,原数据不放到 rollback segment 中,不能回滚,操作不触发 trigger。
 
3.delete 语句不影响表所占用的 extent,高水线(high watermark)保持原位置不动
drop 语句将表所占用的空间全部释放。
truncate 语句缺省情况下见空间释放到 minextents个 extent,除非使用reuse storage;truncate 会将高水线复位(回到最开始)。
 
4.速度,一般来说: drop》 truncate 》 delete
 
5.安全性:小心使用 drop 和 truncate,尤其没有备份的时候.否则哭都来不及
使用上,想删除部分数据行用 delete,注意带上where子句. 回滚段要足够大.
想删除表,当然用 drop
想保留表而将所有数据删除,如果和事务无关,用truncate即可。如果和事务有关,或者想触发trigger,还是用delete。
如果是整理表内部的碎片,可以用truncate跟上reuse stroage,再重新导入/插入数据。

truncate这是个什么函数


定义函数:int truncate(const char * path, off_t length);
函数说明:truncate()会将参数path 指定的文件大小改为参数length 指定的大小. 如果原来的文件大小比参数length 大, 则超过的部分会被删去.
返回值:执行成功则返回0, 失败返回-1, 错误原因存于errno.
-delete

oracle中delete,truncate 和 drop的区别


delete:dml语句,用于删除数据,可以回滚(反悔),可以精确删除。该语句非常耗费资源,需要写undo回滚段,占用大量内存。delete语句是所有dml语句中最消耗资源的语句。
truncat:DDL语句,清除数据。该操作不可回滚,不可精确删除。一旦操作,那么不可找回。节省资源,但是该命令每次清除的基本单位为“段”,比如:table,partition,subpartition等,不能选择清除某些数据。
drop:DDL语句,删除对象操作,上面的delete和truncate都是针对数据的,drop是针对数据的载体的,当然他也可以删除其他的载体,面对基本对象为段。如果不加purge参数,可在回收站找回,否则不可找回。
举个例子:船上有10个人,delete可以定点让某一个人下船,truncate可以让某一层的人下船(分区),或者全部下船,drop就是连船带人一起消失。
-run

truncate和delete的区别


1、空间不同:

表和索引所占空间。当表被truncate 后,这个表和索引所占用的空间会恢复到初始大小,delete操作不会减少表或索引所占用的空间。

2、应用范围不同:

truncate 只能对table;delete可以是table和view。

3、作用不同:

truncate 和delete只删除数据, drop则删除整个表(结构和数据)。

扩展资料:

函数说明:truncate()会将参数path指定的文件大小改为参数length指定的大小。 如果原来的文件大小比参数length大,则超过的部分会被删除

返回值:执行成功则返回0, 失败返回-1, 错误原因存于errno

错误代码:EACCESS 参数path所指定的文件无法存取

EROFS 欲写入的文件存在于只读文件系统内

EFAULT 参数path指针超出可存取空间

参考资料来源:百度百科-truncate