Oracle批量插入數(shù)據(jù)可用PL/SQL的命令窗口執(zhí)行。
創(chuàng)新互聯(lián)服務(wù)項(xiàng)目包括洛川網(wǎng)站建設(shè)、洛川網(wǎng)站制作、洛川網(wǎng)頁制作以及洛川網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,洛川網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到洛川省份的部分城市,未來相信會繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!
使用工具:PL/SQL
步驟:
1、登錄PL/SQL到指定數(shù)據(jù)庫。
2、登錄后,點(diǎn)擊左上方“紙片”狀圖標(biāo),然后選擇“Command
Window”選項(xiàng),進(jìn)入命令窗口。
3、然后在本地電腦編寫insert(即插入語句),每句以逗號分隔。如圖:
4、然后為文件起名字,以.sql為文件后綴,如“執(zhí)行.sql”,保存到指定路徑,如
c盤
data目錄下。
5、在打開的命令窗口下執(zhí)行如下語句:
1
@c:\data\執(zhí)行.sql
其中“@”為必寫內(nèi)容,“c:\data\”為sql文件保存路徑,“執(zhí)行.sql”為要執(zhí)行的腳本文件名。
6、敲擊
回車鍵
執(zhí)行,執(zhí)行后會有成功提示,如圖:
7、最后去目標(biāo)表查詢數(shù)據(jù),檢驗(yàn)結(jié)果成功。其中如圖的四條為新插入的數(shù)據(jù)。
使用loop循環(huán),比如:
for item in (select a,b,c from table_a where 條件) loop
insert into table_b(a,b,c) values (item.a,item.b,item.c);
end loop;
也可以使用索引表循環(huán),以上只是一個簡單的例子,需要根據(jù)你的具體情況選擇循環(huán)方式。
1、采用insert into values 語句插入一條,寫很多條語句即可多條數(shù)據(jù),這種主要針對于離散值以及一些基礎(chǔ)信息的錄入,如:insert into test(xh,mc) values('123','測試');
如果插入的數(shù)據(jù)有規(guī)律,可利用for、loop循環(huán)插入,主要用于批量生成測試數(shù)據(jù)
begin
for i in 1 .. 100 loop
insert into test(xh,mc) values(i||'','測試');
end loop;
end ;。
2、采用insert into selct from 語句來一次性插入一個集合,這種主要依據(jù)于要插入的數(shù)據(jù)源已經(jīng)存儲于數(shù)據(jù)庫對象中,或者利用dual虛表來構(gòu)造數(shù)據(jù),經(jīng)過加工后寫入一個集合。
insert into test (xh,mx) select '123','測試' from dual;
3、采用plsql等工具、或者oracle的imp、impdp命令來導(dǎo)入,這種主要用數(shù)據(jù)庫與數(shù)據(jù)庫之間的大批量數(shù)據(jù)導(dǎo)入,導(dǎo)入的數(shù)據(jù)格式為plsql的pde、oracle的dmp等。dmp文件可使用
table_exists_action參數(shù)控制導(dǎo)入動作:replace替換原表,truncate清除原表數(shù)據(jù)再導(dǎo)入,append增量導(dǎo)入數(shù)據(jù),當(dāng)然impdp數(shù)據(jù)泵的導(dǎo)入要依賴于directory路徑。
impdp 用戶名/密碼 dumpfile=123.dmp logfile=123.log directory=imp_dir tables=test table_exists_action=append。
4、使用excel文件直接拷貝。這種主要用于要寫入的數(shù)據(jù)已是excel文件或者行列分明的其它格式文件,每一列的值和表結(jié)構(gòu)相對應(yīng),可直接打開表的行級鎖,把數(shù)據(jù)拷貝進(jìn)入。
Oracle數(shù)據(jù)的批量插入
前兩天接到一個需求——需要編程將SQL Server中的數(shù)據(jù)插入至Oracle。數(shù)據(jù)大約有20多萬條記錄。開始的時候我采取了直接構(gòu)建SQL插入的方式,結(jié)果耗時太長。為了提高性能我上網(wǎng)找了資料。最終采用DataAdapter批量插入至Oracle,提高了性能。
代碼如下:
一,直接構(gòu)建SQL語句插入
VB.NET Code
二,采用DataAdapter實(shí)現(xiàn)批量插入
VB.NET Code
在我的環(huán)境中批量插入24萬筆記錄用時大約260s左右。
貌似SQL Server中.net驅(qū)動程序提供了SqlBulkCopy類來提高大量數(shù)據(jù)導(dǎo)入的性能。有需要的朋友可以查下MSDN。
本文題目:oracle怎么多條插入,oracle 添加多個字段
網(wǎng)頁路徑:http://jinyejixie.com/article10/dssesdo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供服務(wù)器托管、標(biāo)簽優(yōu)化、網(wǎng)站制作、外貿(mào)網(wǎng)站建設(shè)、做網(wǎng)站、App設(shè)計(jì)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)