教你快速掌握分別刪除數據表記錄的方法

很多情況下我們需要分別刪除數據表的一些記錄,分批來提交以此來減少對于Undo的使用,下面我們提供一個簡單的存儲過程來實現此邏輯。

SQL> create table test as select * from dba_objects;

Table created.

SQL> create or replace procedure deleteTab

2 /**

3 ** Usage: run the script to create the proc deleteTab

4 ** in SQL*PLUS, type "exec deleteTab('Foo','ID>=1000000','3000');"

5 ** to delete the records in the table "Foo", commit per 3000 records.

6 ** Condition with default value '1=1' and default Commit batch is 10000.

7 **/

8 (

9 p_TableName in varchar2, -- The TableName which you want to delete from

10 p_Condition in varchar2 default '1=1', -- Delete condition, such as "id>=100000"

11 p_Count in varchar2 default '10000' -- Commit after delete How many records

12 )

13 as

14 pragma autonomous_transaction;

15 n_delete number:=0;

16 begin

17 while 1=1 loop

18 EXECUTE IMMEDIATE

19 'delete from '||p_TableName||' where '||p_Condition||' and rownum <= :rn'

20 USING p_Count;

21 if SQL%NOTFOUND then

22 exit;

23 else

24 n_delete:=n_delete + SQL%ROWCOUNT;

25 end if;

26 commit;

27 end loop;

28 commit;

29 DBMS_OUTPUT.PUT_LINE('Finished!');

30 DBMS_OUTPUT.PUT_LINE('Totally '||to_char(n_delete)||' records deleted!');

31 end;

32 /

Procedure created.

SQL> insert into test select * from dba_objects;

6374 rows created.

SQL> /

6374 rows created.

SQL> /

6374 rows created.

SQL> commit;

Commit complete.

SQL> exec deleteTab('TEST','object_id >0','3000')

Finished!

Totally 19107 records deleted!

PL/SQL procedure successfully completed.

注釋:在此實例中修正了一下,增加了2個缺省值,以下是具體過程:

create or replace procedure deleteTab

(

p_TableName in varchar2,

-- The TableName which you want to delete from

p_Condition in varchar2 default '1=1',

-- Delete condition, such as "id>=100000"

p_Count in varchar2 default '10000'

-- Commit after delete How many records

)

as

pragma autonomous_transaction;

n_delete number:=0;

begin

while 1=1 loop

EXECUTE IMMEDIATE

'delete from '||p_TableName||'

where '||p_Condition||' and rownum <= :rn'

USING p_Count;

if SQL%NOTFOUND then

exit;

else

n_delete:=n_delete + SQL%ROWCOUNT;

end if;

commit;

end loop;

commit;

DBMS_OUTPUT.PUT_LINE('Finished!');

DBMS_OUTPUT.PUT_LINE('Totally '||to_char(n_delete)||' records deleted!');

注釋:讀者可以根據自己的實際情況來進行適當的調整。

教你快速掌握MySQL數據庫的雙向加密方式
假如你正在運行使用MySQL的Web應用程序,那麽你把密碼或者其他敏感信息保存在應用程序裏的機會就很大。保護這些數據免受黑客或者窺探者的獲取是一個令人關注的重要問題,因爲您既不能讓未經授權的人員使用或者破壞應...查看完整版>>教你快速掌握MySQL數據庫的雙向加密方式
 
教你快速掌握數據庫設計的五種常見關系
數據庫設計的5種常見關系(本文主要講解“多態”關系結構)。 ◆1.配置關系 --和其他表無任何關系的表。 ◆2.一對多關系 ,一張表包含另外一個表的主鍵作爲外鍵。 ◆3.多對多,需要2張表,有一個包含兩個外鍵的關系表...查看完整版>>教你快速掌握數據庫設計的五種常見關系
 
教你快速掌握數據庫設計範式的基本概念
由于數據庫設計中所遵循的範式規則比較複雜,對于初學者來講很難完全記住,本文針對數據庫設計範式的基本概念進行了扼要的總結。 第一範式: 對于表中的每一行,必須且僅僅有唯一的行值.在一行中的每一列僅有唯一的值...查看完整版>>教你快速掌握數據庫設計範式的基本概念
 
教你快速掌握Oracle數據庫結構的16個要點
本文主要介紹了學習Oracle數據庫結構所應掌握的16個要點,詳細內容請大家參考下文: 1、一個數據文件只能歸到某一個表空間上,每個表空間可以含一個或多個數據文件。包括系統數據和用戶數據。 2、表空間是包括一個或...查看完整版>>教你快速掌握Oracle數據庫結構的16個要點
 
教你快速掌握DB2數據庫創建外鍵時的選項
創建外鍵時的選項: 1.創建測試表: drop table student; drop table class; drop table student_class; Create table student(student_id integer not null,student_name varchar(200), CONSTRAINT P_KEY_1 primary...查看完整版>>教你快速掌握DB2數據庫創建外鍵時的選項
 
教你快速掌握Oracle數據庫中的 bfile
具體步驟如下:1.先在Oracle數據庫中下面我們建立一個目錄別名,用于將文件定位指針映射到文件系統:create DirectorY 'tmpdir' AS '/tmp';tmpdir表示邏輯目錄名,'/tmp'是實際目錄。 注重該目錄oracle應該有讀權限 然...查看完整版>>教你快速掌握Oracle數據庫中的 bfile
 
教你快速掌握常見的幾種數據庫對象
  教你快速掌握常見的幾種數據庫對象。注釋:數據庫對象是數據庫的組成部分,常見的有以下幾種:  1.表(Table )  數據庫中的表與我們日常生活中使用的表格類似,它也是由行(Row) 和列(Column)組成的。列由同類...查看完整版>>教你快速掌握常見的幾種數據庫對象
 
教你快速掌握如何向MySQL的表中錄入數據
當我們建好數據庫及表後,首先想到的就是向數據庫的表中輸入數據.下面我們就來探討一下如何向數據庫增加數據:   1.常用的方法是insert語句   insert into tablename values(value1,value2,...)    insert int...查看完整版>>教你快速掌握如何向MySQL的表中錄入數據
 
教你快速掌握IBM DB2數據庫的性能參數
本文中,表內的"性能影響"列指示每個參數影響系統性能的相對程度。但不可以將此列准確地應用于所有環境;讀者應該將此信息視爲一般的情況。 高:指示該參數可以對性能有重要影響。應有意識地決定這些參數的值;在某些...查看完整版>>教你快速掌握IBM DB2數據庫的性能參數
 
 
回到王朝網路移動版首頁