oracle數(shù)據(jù)庫(kù)刪除數(shù)據(jù)Delete語(yǔ)句和Truncate語(yǔ)句的使用比較
更新時(shí)間:2012年09月12日 19:41:56 作者:
oracle當(dāng)表中的數(shù)據(jù)不需要時(shí),則應(yīng)該刪除該數(shù)據(jù)并釋放所占用的空間,刪除表中的數(shù)據(jù)可以使用Delete語(yǔ)句或者Truncate語(yǔ)句,下面分別介紹
當(dāng)表中的數(shù)據(jù)不需要時(shí),則應(yīng)該刪除該數(shù)據(jù)并釋放所占用的空間,刪除表中的數(shù)據(jù)可以使用Delete語(yǔ)句或者Truncate語(yǔ)句,下面分別介紹。
一、delete語(yǔ)句
(1)有條件刪除
語(yǔ)法格式:delete [from] table_name [where condition];
如:刪除users表中的userid為‘001'的數(shù)據(jù):delete from users where userid='001';
(2)無(wú)條件刪除整個(gè)表數(shù)據(jù)
語(yǔ)法格式:delete table_name;
如:刪除user表中的所有數(shù)據(jù):delete users ;
二、Truncate語(yǔ)句
使用Truncate語(yǔ)句是刪除表中的所有記錄。
語(yǔ)法格式: Truncate [table] table_name;
(1)刪除所有記錄不保留記錄占用空間
Truncate [table] table_name [drop storage];
如:刪除users表中的所有數(shù)據(jù)并不保存占用空間: Truncate table users drop storage; 由于默認(rèn)使用drop storage關(guān)鍵字,所以可以省略 drop storage;
(2)刪除所有記錄保留記錄占用空間
Truncate [table] table_name [reuse storage];
如:刪除users表中的所有數(shù)據(jù)并保存占用空間: Truncate table users reuse storage;
三、兩種刪除語(yǔ)句的對(duì)比
由于delete語(yǔ)句刪除記錄時(shí)候,記錄是逐條刪除的,而Truncate 語(yǔ)句刪除數(shù)據(jù)時(shí)不產(chǎn)生回退信息;所以如果需要?jiǎng)h除大量數(shù)據(jù)的時(shí)候使用delete則占用較多的系統(tǒng)資源,而如果使用Truncate 則會(huì)快的多。
下面通過(guò)實(shí)例說(shuō)明一下:
1、首先建立user表:
create table users
(
userid varchar2(20) ,
username varchar2(30),
userpass varchar2(30)
);復(fù)制代碼
2、接著插入一條數(shù)據(jù)
insert into users values('001','GavinDream','123456'); 3、使用復(fù)制插入方法插入幾萬(wàn)條數(shù)據(jù)
insert into users(userid,username,userpass) select * from users;我插入了 4194304條數(shù)據(jù),使用delete刪除花費(fèi)時(shí)間為:90.964 seconds,然后又插入了二倍的數(shù)據(jù),但使用truncate花費(fèi)時(shí)間僅僅為2.215 seconds,如下圖所示:

一、delete語(yǔ)句
(1)有條件刪除
語(yǔ)法格式:delete [from] table_name [where condition];
如:刪除users表中的userid為‘001'的數(shù)據(jù):delete from users where userid='001';
(2)無(wú)條件刪除整個(gè)表數(shù)據(jù)
語(yǔ)法格式:delete table_name;
如:刪除user表中的所有數(shù)據(jù):delete users ;
二、Truncate語(yǔ)句
使用Truncate語(yǔ)句是刪除表中的所有記錄。
語(yǔ)法格式: Truncate [table] table_name;
(1)刪除所有記錄不保留記錄占用空間
Truncate [table] table_name [drop storage];
如:刪除users表中的所有數(shù)據(jù)并不保存占用空間: Truncate table users drop storage; 由于默認(rèn)使用drop storage關(guān)鍵字,所以可以省略 drop storage;
(2)刪除所有記錄保留記錄占用空間
Truncate [table] table_name [reuse storage];
如:刪除users表中的所有數(shù)據(jù)并保存占用空間: Truncate table users reuse storage;
三、兩種刪除語(yǔ)句的對(duì)比
由于delete語(yǔ)句刪除記錄時(shí)候,記錄是逐條刪除的,而Truncate 語(yǔ)句刪除數(shù)據(jù)時(shí)不產(chǎn)生回退信息;所以如果需要?jiǎng)h除大量數(shù)據(jù)的時(shí)候使用delete則占用較多的系統(tǒng)資源,而如果使用Truncate 則會(huì)快的多。
下面通過(guò)實(shí)例說(shuō)明一下:
1、首先建立user表:
create table users
(
userid varchar2(20) ,
username varchar2(30),
userpass varchar2(30)
);復(fù)制代碼
2、接著插入一條數(shù)據(jù)
insert into users values('001','GavinDream','123456'); 3、使用復(fù)制插入方法插入幾萬(wàn)條數(shù)據(jù)
insert into users(userid,username,userpass) select * from users;我插入了 4194304條數(shù)據(jù),使用delete刪除花費(fèi)時(shí)間為:90.964 seconds,然后又插入了二倍的數(shù)據(jù),但使用truncate花費(fèi)時(shí)間僅僅為2.215 seconds,如下圖所示:

相關(guān)文章
rman恢復(fù)方案和oracle異機(jī)恢復(fù)
這篇文章主要介紹了rman恢復(fù)方案和oracle異機(jī)恢復(fù),需要的朋友可以參考下2014-03-03
Oracle用戶密碼過(guò)期報(bào)錯(cuò)的解決辦法
Oracle數(shù)據(jù)庫(kù) 11g默認(rèn)密碼過(guò)期時(shí)間為180天過(guò)期,針對(duì)密碼過(guò)期企業(yè)一般是采用修改密碼的方式,個(gè)人電腦上則可以將密碼過(guò)期時(shí)間修改為永久,本文給大家介紹了Oracle用戶密碼過(guò)期報(bào)錯(cuò)的解決辦法,需要的朋友可以參考下2024-03-03
Oracle跨數(shù)據(jù)庫(kù)查詢并插入實(shí)現(xiàn)原理及代碼
需要從一個(gè)數(shù)據(jù)庫(kù)中的表GIS_WEICHAI_DATA_1S中的數(shù)據(jù)導(dǎo)入到另個(gè)一數(shù)據(jù)庫(kù)的表GIS_WEICHAI_DATA_1S中,接下來(lái)為你講解跨數(shù)據(jù)庫(kù)查詢并插入需要的朋友可以參考下2013-03-03
Oracle使用pivot和unpivot函數(shù)實(shí)現(xiàn)行列轉(zhuǎn)換
項(xiàng)目開(kāi)發(fā)過(guò)程中常常會(huì)涉及到oracle數(shù)據(jù)庫(kù)的一個(gè)數(shù)據(jù)操作,那就是行列的互轉(zhuǎn),本文為大家介紹了兩個(gè)可以實(shí)現(xiàn)這一操作的函數(shù)pivot和unpivot,感興趣的可以了解一下2023-06-06
oracle報(bào)錯(cuò)(ORA-00600)問(wèn)題處理
最近在做一個(gè)項(xiàng)目,使用的是Oracle數(shù)據(jù)庫(kù),近兩天不知道怎么回事,告警日志里總是顯示這個(gè)錯(cuò)誤(ORA-00600:internalerrorcode,arguments:[kcblasm_1],[103],[],[],[],[],[],[])度娘了一下,終于找到解決方式,分享給大家2014-08-08
oracle增加表空間大小兩種實(shí)現(xiàn)方法
增加表空間大小:一種是為表空間增加數(shù)據(jù)文件/另一種方法是增加表空間原有數(shù)據(jù)文件尺寸,感興趣的朋友可以了解下,或許對(duì)你有所幫助2013-01-01

