关于SQL删除语句TRUNCATE和DELETE的问题 请问,TRUNCATE和DELETE的相同点是什么?不同点是什么?以及在什么情况下分别使用这两个语句?最好不要copy,请前辈关注一下。。
详解Oracle DELETE和TRUNCATE 的区别
如何降低Oracle表的高水位 1.执行表重建指令 alter table table_name move(验证不可行,不降低水位线,但可释放表空间)当你创建了一个对象如表以后,不管你有没有插入数据,它都会占用一些块,ORACLE也会给它分配必要的空间.同样,用ALTER TABLE MOVE释放自由空间后,还是保留了一些空间给这个表.ALTER TABLE.MOVE 后面不跟参数也行,不跟参数表还是在原来的表空间,Move后记住重建索引.查询失效索引语句:select index_name,table_name,tablespace_name,status From dba_indexes Where owner='HNUNICOM' And status<;>;'VALID';重建索引语句:alter index INDEX_NAME rebuild tablespace TABLESPACE_NAME;如果以后还要继续向这个表增加数据,没有必要move,只是释放出来的空间,只能这个表用,其他的表或者segment无法使用该空间。2.执行alter table table_name shrink space;(已经验证成功,推荐使用,可释放数据库和磁盘空间空间,大表可同时降低表自身和表空间的高水位线,小表则只可以降低表自身的高水位线,原因不详)注意,此命令为Oracle 10g新增功能,执行该指令之前必须允许行移动 alter table table_name enable row movement;3.复制要保留的数据到临时表t,drop原表,然后rename。
oracle删除一张表里面的数据之后,在往这个表里面插数据,那删除的空间是不是可以用 当然可以了,你删除提交以后,空间就会被释放的
关于SQL删除语句TRUNCATE和DELETE的问题 理解了本质你才会适时而用!truncate你可以理解为ddl,delete是dml。ddl和dml的定义我不多说了。truncate删数就跟直接格式化硬盘类似,不管有多少数据,我就直接删除,跟drop表一样,无非就是空表留下了。速度不用提,快的很!delete删除是事务性的一条条删,要记录各种日志,以防你反悔回滚!因此删一条,记录一条,慢死!但是,并不是那个快就胡乱用,如果你平时总是需要整表删,那么你用哪个清楚了吧嘿嘿delete往往用在事务性操作里面,比如删除一条多条数据,如果你用delete删除整表,实在浪费资源,而且对oracle来说,delete不会降低高水位,因此删的次数多了表操作会变慢!这是讲删除整表时的操作,记住凡事都有两面性!truncate删除不可恢复!delete还可以恢复!说了那么多,关键看怎么用,多多实践。我闲着没事干,打了这些字,算是理解这两个东西的基本入门概念,算是抛砖引玉!有分不用给我,因为我的这些概念到处都有。真正去用看自己了,那才是谷歌都没法查到的东西。
请问TRUNCATE TABLE 与 DELETE在删除整个表的所有记录时的区别 TRUNCATE TABLE 和不带2113 WHERE 的 DELETE 功能是一样的,都是删5261除表中的所有数据,不4102过 TRUNCATE TABLE 速度更快,占用的日1653志更专少,这是因为 TRUNCATE TABLE 直接释放数据页属并且在事务日志中也只记录数据页的释放,而 DELETE 是一行一行地删除,在事务日志中要记录每一条记录的删除。
oracle 批量插入和删除,会不会减少日志量呢 insert/*+append*/的有点事insert速度快,但是占用空间多truncate 是直接降低高水位,会收缩删除的空间的但是delete不会降低高水位,即使删除了数据,空间也不会减少的可以再delete 提交以后,move一下表就会释放这些空间了