国产一级a片免费看高清,亚洲熟女中文字幕在线视频,黄三级高清在线播放,免费黄色视频在线看

打開APP
userphoto
未登錄

開通VIP,暢享免費電子書等14項超值服

開通VIP
oracle用存儲過程導出INSERT INTO 語句

前些天看到幾個朋友做導出oracle中的數(shù)據(jù),可以用PL/SQL Devoleper的和export tables功能批量將N個表的數(shù)據(jù)導出成insert into語句,但怎樣用SQL語句導出呢,只有用sql構(gòu)造出來,以下是我用存儲過程實現(xiàn)的代碼

create or replace package PK_EXPORT_TABLE  is  type result is ref cursor;end ;

CREATE OR REPLACE PROCEDURE P_EXPORT_TABLE(v_table in varchar,
cresult out PK_EXPORT_TABLE.result
--outstr out varchar2 /*測試SQL*/
)
/*----------------------------------------------------------------------------------------
  功能要求:導出sql語名,格式為INSERT INTO TABLE(。。。)VALUES(。。。);
  編寫人:chimo
  編寫開始日期:   20080120
  編寫結(jié)束日期:20080120
  參數(shù)定義:    表名v_table,cresult是一個自定義游標!
  自定義游標:create or replace package PK_EXPORT_TABLE  is  type result is ref cursor;end PK_EXPORT_TABLE;
  數(shù)據(jù)來源:
  調(diào)用方法:其它語言中調(diào)用,PL/SQL過程中   如:EXEC p_xqcn_cycsjcx ('參數(shù)1');
  -----------------------------------------------------------------------------------------*/
as
TYPE v_cur_tab_columns IS REF CURSOR;/*表各字段信息*/
v_tab_columns v_cur_tab_columns;
v_sql_columns varchar2(500);/*查詢字段信息*/
v_column_infor user_tab_columns%rowtype; /*行字錄各字段數(shù)型為USRE_TAB_COLUMNS*/
v_sqlstr_part_1 varchar2(200):='';/*存放形成sql的第一部分*/
v_sqlstr_part_2 varchar2(500):='';/*存放形成sql的第二部分*/
v_sqlstr_part_3 varchar2(4000):='';/*存放形成sql的第三部分*/
v_sql varchar2(5000):='';/*存放形成的sql*/
v_sqlneed varchar2(100):=','||''''||','||''''||','; /*形成在VALUES中的分隔符 ”, “ */
begin
v_sqlstr_part_1:='insert into '||upper(v_table)||' (';
/*查詢表中各字段信息*/
v_sql_columns:='select * from user_tab_columns where table_name='||''''||UPPER(v_table)||''''||' AND data_type not in ('||''''||'BLOB'||''''||','||''''||'CLOB'||''''||') AND ROWNUM<20';
open  v_tab_columns for v_sql_columns;
loop
fetch v_tab_columns into v_column_infor;
exit when v_tab_columns%notfound;
/*用于形成insert into table (。。。)中的字段*/
    v_sqlstr_part_2:=v_sqlstr_part_2||v_column_infor.COLUMN_NAME||',';
    /*用于形成values (。。。)中的字段*/
    v_sqlstr_part_3:=case
    when v_column_infor.DATA_TYPE='DATE' THEN v_sqlstr_part_3||'to_date(to_char('||'BZRQ'||','||''''||'yyyy-mm-dd hh24:mi:ss'||''''||'), '||''''||'yyyy-mm-dd hh24:mi:ss'||''''||')'||v_sqlneed   
    when v_column_infor.DATA_TYPE='VARCHAR2' OR v_column_infor.DATA_TYPE='VARCHAR' or v_column_infor.DATA_TYPE='CHAR' THEN v_sqlstr_part_3||' case when '||v_column_infor.column_name||' IS NOT NULL THEN '||''''''''''||'||'||v_column_infor.COLUMN_NAME||'||'||''''''''''||' ELSE NULL END AS '||v_column_infor.COLUMN_NAME||v_sqlneed
    when v_column_infor.DATA_TYPE='NUMBER' THEN v_sqlstr_part_3||' case when '||v_column_infor.column_name||' IS NOT NULL THEN '||v_column_infor.COLUMN_NAME||' ELSE NULL END AS '||v_column_infor.COLUMN_NAME||v_sqlneed
    else
    --v_sqlstr_part_3||' case when '||v_column_infor.column_name||' IS NOT NULL THEN '||''''''''''||'||'||v_column_infor.COLUMN_NAME||'||'||''''''''''||' ELSE NULL END AS '||v_column_infor.COLUMN_NAME||v_sqlneed
    v_sqlstr_part_3||'NULL'||v_sqlneed
    end;   
end loop;
/*去掉最后的“,”并加上VALUES*/
v_sqlstr_part_2:=substr(v_sqlstr_part_2,0,length(v_sqlstr_part_2)-1)||') values (';
/*去掉最后的“,“*/
v_sqlstr_part_3:=substr(v_sqlstr_part_3,0,length(v_sqlstr_part_3)-5)||','||''')''';
/*形成的sql*/
v_sql:='SELECT '''||v_sqlstr_part_1||v_sqlstr_part_2||''''||','||v_sqlstr_part_3||' FROM '||upper(v_table)||' ';
/*打開游標并返回*/
open cresult for v_sql;
Exception
when others then
  open cresult for 'select * from '||v_table;
--outstr:=v_sql;
end P_EXPORT_TABLE;

本站僅提供存儲服務,所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊舉報。
打開APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
SQL基礎入門:第5課:操縱表
復習常用的SQL以及一些函數(shù)
Oracle 外鍵創(chuàng)建及使用
《SQL Server》之 表的創(chuàng)建和管理
oracle命名規(guī)范與保留字介紹!
《SQLServer數(shù)據(jù)庫應用基礎教程》第三章數(shù)據(jù)表的建立
更多類似文章 >>
生活服務
分享 收藏 導長圖 關注 下載文章
綁定賬號成功
后續(xù)可登錄賬號暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點擊這里聯(lián)系客服!

聯(lián)系客服