Oracle不支持也沒有SqlBulkCopy類,那個只有SqlServer數據庫才支持,Oracle可以用數組形式的參數批量提交來實現,但那個絕對不能叫“BulkCopy”。

我們提供的服務有:網站設計制作、成都網站設計、微信公眾號開發、網站優化、網站認證、天等ssl等。為上千余家企事業單位解決了網站和推廣的問題。提供周到的售前咨詢和貼心的售后服務,是有科學管理、有技術的天等網站制作公司
OracleCommand command = new OracleCommand("鏈接字符串");
command.ArrayBindCount = 1000;
command.CommandText = "insert into dept values(:deptno, :deptname, :loc)";
int[] deptNo = new int[1000];
string[] dname = new string[1000];
string[] loc = new string[1000];
command.Parameters.Add(new OracleParameter("deptno", OracleDbType.Int32) { Value = deptNo });
command.Parameters.Add(new OracleParameter("dname", OracleDbType.Varchar2) { Value = dname });
command.Parameters.Add(new OracleParameter("loc", OracleDbType.Varchar2) { Value = loc });
command.ExecuteNonQuery();
前提:在做insert數據之前,如果是非生產環境,請將表的索引和約束去掉,待insert完成后再建索引和約束。
insert into tab1 select * from tab2; commit;
這是最基礎的insert語句,我們把tab2表中的數據insert到tab1表中。根據經驗,千萬級的數據可在1小時內完成。但是該方法產生的arch會非常快,需要關注歸檔的產生量,及時啟動備份軟件,避免arch目錄撐爆。
alter table tab1 nologging;
insert /*+ append */ into tab1 select * from tab2;
commit; alter table tab1 logging;
該方法會使得產生arch大大減少,并且在一定程度上提高時間,根據經驗,千萬級的數據可在45分鐘內完成。但是請注意,該方法適合單進程的串行方式,如果當有多個進程同時運行時,后發起的進程會有enqueue的等待。注意此方法千萬不能dataguard上用,不過要是在database已經force logging那也是沒有問題的。
insert into tab1 select /*+ parallel */ * from tab2; commit;
對于select之后的語句是全表掃描的情況,我們可以加parallel的hint來提高其并發,這里需要注意的是最大并發度受到初始化參數parallel_max_servers的限制,并發的進程可以通過v$px_session查看,或者ps -ef |grep ora_p查看。
alter session enable parallel dml;
insert /*+ parallel */ into tab1 select * from tab2; commit;
其他方法:
并發的insert,尚未比較和方法2哪個效率更高(偶估計是方法2快),有測試過的朋友歡迎補充。
insert into tab1 select * from tab2 partition (p1);
insert into tab1 select * from tab2 partition (p2);
insert into tab1 select * from tab2 partition (p3);
insert into tab1 select * from tab2 partition (p4);
對于分區表可以利用tab1進行多個進程的并發insert,分區越多,可以啟動的進程越多。我曾經試過insert 2.6億行記錄的一個表,8個分區,8個進程,如果用方法2,單個進程完成可能要40分鐘,但是由于是有8個分區8個進程,后發進程有enqueue,所以因此需要的時間為40分鐘×8;但是如果用方法5,雖然單個進程需要110分鐘,但是由于能夠并發進程執行,所以總共需要的時間就約為110分鐘了。
DECLARE TYPE dtarray IS TABLE OF VARCHAR2(20)
INDEX BY BINARY_INTEGER;
v_col1 dtarray; v_col2 dtarray; v_col3 dtarray;
BEGIN SELECT col1, col2, col3 BULK COLLECT INTO v_col1, v_col2, v_col3
FROM tab2;
FORALL i IN 1 .. v_col1.COUNT insert into tab1
WHERE tab1.col1 = v_col1;
END;
用批量綁定(bulk binding)的方式。當循環執行一個綁定變量的sql語句時候,在PL/SQL 和SQL引擎(engines)中,會發生大量的上下文切換(context switches)。使用bulk binding,能將數據批量的從plsql引擎傳到sql引擎,從而減少上下文切換過程,提升效率。該方法比較適合于在線處理,不必停機。
sqlplus -s user/pwd runlog.txt set copycommit 2;
set arraysize 5000;
copy from user/pwd@sid - to user/pwd@sid - insert tab1 using
select * from tab2; exit EOF
用copy的方法進行插入,注意此處insert沒有into關鍵字。該方法的好處是可以設置copycommit和arrarysize來一起控制commit的頻率,上面的方法是每10000行commit一次。
1、采用insert into values 語句插入一條,寫很多條語句即可多條數據,這種主要針對于離散值以及一些基礎信息的錄入,如:insert into test(xh,mc) values('123','測試');
如果插入的數據有規律,可利用for、loop循環插入,主要用于批量生成測試數據
begin
for i in 1 .. 100 loop
insert into test(xh,mc) values(i||'','測試');
end loop;
end ;。
2、采用insert into selct from 語句來一次性插入一個集合,這種主要依據于要插入的數據源已經存儲于數據庫對象中,或者利用dual虛表來構造數據,經過加工后寫入一個集合。
insert into test (xh,mx) select '123','測試' from dual;
3、采用plsql等工具、或者oracle的imp、impdp命令來導入,這種主要用數據庫與數據庫之間的大批量數據導入,導入的數據格式為plsql的pde、oracle的dmp等。dmp文件可使用
table_exists_action參數控制導入動作:replace替換原表,truncate清除原表數據再導入,append增量導入數據,當然impdp數據泵的導入要依賴于directory路徑。
impdp 用戶名/密碼 dumpfile=123.dmp logfile=123.log directory=imp_dir tables=test table_exists_action=append
4、使用excel文件直接拷貝。這種主要用于要寫入的數據已是excel文件或者行列分明的其它格式文件,每一列的值和表結構相對應,可直接打開表的行級鎖,把數據拷貝進入。
打開行級鎖方法:
select t.*,rowid from 表名 t where 1=2;
select * from 表名 where 1=2 for update;
直接把excel數據拷貝到表里
Oracle批量插入數據可用PL/SQL的命令窗口執行。
使用工具:PL/SQL
步驟:
1、登錄PL/SQL到指定數據庫。
2、登錄后,點擊左上方“紙片”狀圖標,然后選擇“Command Window”選項,進入命令窗口。
3、然后在本地電腦編寫insert(即插入語句),每句以逗號分隔。如圖:
4、然后為文件起名字,以.sql為文件后綴,如“執行.sql”,保存到指定路徑,如c盤data目錄下。
5、在打開的命令窗口下執行如下語句:
@c:\data\執行.sql
其中“@”為必寫內容,“c:\data\”為sql文件保存路徑,“執行.sql”為要執行的腳本文件名。
6、敲擊回車鍵執行,執行后會有成功提示,如圖:
7、最后去目標表查詢數據,檢驗結果成功。其中如圖的四條為新插入的數據。
在oracle中將查詢到的數據插入到另一個表中:
1、Insert into t_tab
2、select * from ?s_tab where 條件
Oracle Database,又名Oracle RDBMS,或簡稱Oracle。
是甲骨文公司的一款關系數據庫管理系統。它是在數據庫領域一直處于領先地位的產品。可以說Oracle數據庫系統是目前世界上流行的關系數據庫管理系統,系統可移植性好、使用方便、功能強,適用于各類大、中、小、微機環境。
它是一種高效率、可靠性好的 適應高吞吐量的數據庫解決方案。
嵌套一個select語句在values這里,把你要插入的一整列語句用一根select語句查詢出來,再賦值給values里面的值。
按位置對應一下,batch在段在倒數第二位,所以那個地方直接引用序列。
Oracle 常用SQL語法和數據對象,字符串類型的字段值超過定義的長度會出錯,最好在插入前進行長度校驗。
日期字段的字段值可以用當前數據庫的系統時間SYSDATE精確到秒。
INSERT時最大可操作的字符串長度小于等于4000個單字節,方法借用ORACLE里自帶的DBMS_LOB程序包。
                標題名稱:oracle中如何插入,oracle 導入語句
                
                瀏覽路徑:http://www.yijiale78.com/article24/dschcce.html
            
成都網站建設公司_創新互聯,為您提供網站建設、網站策劃、云服務器、營銷型網站建設、網站維護、建站公司
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯
