生成某一使用者下所有表資料的insert語句
轉自王工的部落格
http://blog.csdn.net/wzy0623/article/details/8445228
CREATE OR REPLACE DIRECTORY mydir AS 'C:\';
DECLARE
ROW_NUMBER NUMBER := 0;
col_str VARCHAR2 (32767) := '';
select_str VARCHAR2 (32767) := '';
ins_tab DBMS_SQL.varchar2_table;
l_count INT := 0;
log_file UTL_FILE.file_type;
BEGIN
log_file := UTL_FILE.fopen ('MYDIR', 'insert.sql', 'w');
UTL_FILE.put_line (log_file, 'set define off;');
FOR x IN (SELECT table_name FROM user_tables)
LOOP
EXECUTE IMMEDIATE 'select count(*) from ' || x.table_name
INTO ROW_NUMBER;
IF ROW_NUMBER > 0
THEN
col_str := '';
select_str := '';
FOR y IN ( SELECT column_name, data_type
FROM user_tab_columns
WHERE table_name = x.table_name AND data_type != 'BLOB'
ORDER BY column_id)
LOOP
col_str := col_str || y.column_name || ',';
IF y.data_type = 'NUMBER'
THEN
select_str :=
select_str
|| 'decode('
|| y.column_name
|| ',null,''null'','
|| y.column_name
|| ')||'',''||';
ELSE
IF y.data_type IN ('CHAR', 'VARCHAR2', 'LONG', 'CLOB')
THEN
select_str :=
select_str
|| 'decode('
|| y.column_name
|| ',null,''null'',''''''''||replace('
|| y.column_name
|| ','''''''','''''''''''')||'''''''')||'',''||';
ELSE
IF y.data_type = 'DATE'
THEN
select_str :=
select_str
|| 'decode('
|| y.column_name
|| ',null,''null'',''to_date(''''''||'
|| 'to_char('
|| y.column_name
|| ',''yyyy-mm-dd hh24:mi:ss'')||'''
|| '''||'''''',''''yyyy-mm-dd hh24:mi:ss'''')'')||'',''||';
END IF;
END IF;
END IF;
END LOOP;
col_str := 'insert into ' || x.table_name || ' (' || col_str;
col_str := SUBSTR (col_str, 1, LENGTH (col_str) - 1) || ') values (';
select_str :=
'select '''
|| col_str
|| ''' ||'
|| SUBSTR (select_str, 1, LENGTH (select_str) - 7)
|| '|| '');'' from '
|| x.table_name;
-- dbms_output.put_line(select_str);
EXECUTE IMMEDIATE select_str BULK COLLECT INTO ins_tab;
l_count := ins_tab.COUNT;
UTL_FILE.put_line (log_file, '');
UTL_FILE.put_line (log_file, '-- table name: ' || x.table_name);
FOR i IN 1 .. l_count
LOOP
UTL_FILE.put_line (log_file, ins_tab (i));
END LOOP;
END IF;
END LOOP;
UTL_FILE.put_line (log_file, '');
UTL_FILE.put_line (log_file, 'commit;');
UTL_FILE.fclose (log_file);
END;
/
注意王工部落格程式碼的75行,有個筆誤,少了兩個 ' 符號。
|| '|| ''); from '
應為
|| '|| '');'' from '
http://blog.csdn.net/wzy0623/article/details/8445228
功能:生成某一使用者下所有資料表資料的insert語句,放入d:\insert.sql檔案。
限制:只支援number、char、varchar2、date、long、clob資料型別。
提示:資料量小還可以,大了就別用這種方式了,會很慢。
CREATE OR REPLACE DIRECTORY mydir AS 'C:\';
DECLARE
ROW_NUMBER NUMBER := 0;
col_str VARCHAR2 (32767) := '';
select_str VARCHAR2 (32767) := '';
ins_tab DBMS_SQL.varchar2_table;
l_count INT := 0;
log_file UTL_FILE.file_type;
BEGIN
log_file := UTL_FILE.fopen ('MYDIR', 'insert.sql', 'w');
UTL_FILE.put_line (log_file, 'set define off;');
FOR x IN (SELECT table_name FROM user_tables)
LOOP
EXECUTE IMMEDIATE 'select count(*) from ' || x.table_name
INTO ROW_NUMBER;
IF ROW_NUMBER > 0
THEN
col_str := '';
select_str := '';
FOR y IN ( SELECT column_name, data_type
FROM user_tab_columns
WHERE table_name = x.table_name AND data_type != 'BLOB'
ORDER BY column_id)
LOOP
col_str := col_str || y.column_name || ',';
IF y.data_type = 'NUMBER'
THEN
select_str :=
select_str
|| 'decode('
|| y.column_name
|| ',null,''null'','
|| y.column_name
|| ')||'',''||';
ELSE
IF y.data_type IN ('CHAR', 'VARCHAR2', 'LONG', 'CLOB')
THEN
select_str :=
select_str
|| 'decode('
|| y.column_name
|| ',null,''null'',''''''''||replace('
|| y.column_name
|| ','''''''','''''''''''')||'''''''')||'',''||';
ELSE
IF y.data_type = 'DATE'
THEN
select_str :=
select_str
|| 'decode('
|| y.column_name
|| ',null,''null'',''to_date(''''''||'
|| 'to_char('
|| y.column_name
|| ',''yyyy-mm-dd hh24:mi:ss'')||'''
|| '''||'''''',''''yyyy-mm-dd hh24:mi:ss'''')'')||'',''||';
END IF;
END IF;
END IF;
END LOOP;
col_str := 'insert into ' || x.table_name || ' (' || col_str;
col_str := SUBSTR (col_str, 1, LENGTH (col_str) - 1) || ') values (';
select_str :=
'select '''
|| col_str
|| ''' ||'
|| SUBSTR (select_str, 1, LENGTH (select_str) - 7)
|| '|| '');'' from '
|| x.table_name;
-- dbms_output.put_line(select_str);
EXECUTE IMMEDIATE select_str BULK COLLECT INTO ins_tab;
l_count := ins_tab.COUNT;
UTL_FILE.put_line (log_file, '');
UTL_FILE.put_line (log_file, '-- table name: ' || x.table_name);
FOR i IN 1 .. l_count
LOOP
UTL_FILE.put_line (log_file, ins_tab (i));
END LOOP;
END IF;
END LOOP;
UTL_FILE.put_line (log_file, '');
UTL_FILE.put_line (log_file, 'commit;');
UTL_FILE.fclose (log_file);
END;
/
注意王工部落格程式碼的75行,有個筆誤,少了兩個 ' 符號。
|| '|| ''); from '
應為
|| '|| '');'' from '
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/29254281/viewspace-1065181/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- oracle-資料庫- insert 插入語句Oracle資料庫
- 用儲存過程把表裡的資料導成insert語句儲存過程
- PostgreSQL:所有支援的資料型別及建表語句例項SQL資料型別
- DBeaver如何生成select,update,delete,insert語句delete
- Oracle 刪除使用者、表空間、資料檔案、使用者下的所有表Oracle
- SQLite Insert 語句SQLite
- 利用MySQL原資料資訊批量轉換指定庫資料表生成Hive建表語句MySqlHive
- mysql資料庫語句自動生成MySql資料庫
- SQL語句圖表生成工具ChartSQLSQL
- SQLite中特殊的INSERT語句SQLite
- 刪除使用者及使用者下的所有資料
- excel表結構生成powerDesigner模型,生成建表語句sqlExcel模型SQL
- 資料庫-單表結構-建表語句資料庫
- 定時生成分月表sql語句SQL
- Oracle表部分資料提取SQL語句OracleSQL
- 遞迴遍歷磁碟下的某一資料夾中所有檔案,並copy檔案生成檔案和帶資料夾的檔案遞迴
- 如何刪除資料庫下的所有表(mysql)資料庫MySql
- 編寫迴圈插入表資料的語句。
- 12c 資料泵提取建表空間語句和建表語句
- 【SQL】9 SQL INSERT INTO 語句SQL
- Sql Server系列:Insert語句SQLServer
- INSERT...SELECT語句對查詢的表加鎖嗎
- MySQL INSERT IGNORE語句的使用MySql
- 通過實體類生成 mysql 的建表語句MySql
- 恢復update,delete表資料錯誤的語句delete
- 清除使用者下所有的資料(清庫)
- 大量包含Insert語句的指令碼檔案批量執行匯入資料指令碼
- 教你使用SQLite-insert語句SQLite
- 快速執行大量 insert 語句的方法
- 刪除資料庫所有使用者表(SqlServer)資料庫SQLServer
- 【Oracle】scott使用者下表結構、初始化資料和建表語句Oracle
- 報表和儀表板生成器Stimulsoft資訊:將所有資料嵌入資源
- mysql捕捉所有SQL語句MySql
- oracle檢視當前使用者下所有外來鍵、主鍵、索引、sequence的建立語句Oracle索引
- oracle中建立insert select from 語句實現兩個表中某一個欄位相同統計其他不同欄位的情況Oracle
- DBeave如何檢視資料庫表的DDL建立語句資料庫
- 複製表結構和資料SQL語句SQL
- 【SQL】14 UNION 操作符、SELECT INTO 語句、INSERT INTO SELECT 語句、CREATE DATABASE 語句、CREATE TABLE 語句SQLDatabase