版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、第7章第7章 數(shù)據(jù)的導入和導出 大多應(yīng)用程序都設(shè)計成允許用戶操作單獨的數(shù)據(jù)。但實際應(yīng)用中經(jīng)常都需要導入或?qū)С龃罅繑?shù)據(jù)。 導入大量數(shù)據(jù)時,使用INSERT語句的執(zhí)行效率不是特別好。 導出數(shù)據(jù)時,若向應(yīng)用程序返回一個結(jié)果集,再由應(yīng)用程序?qū)⑿袑懭胛募蚱渌康牡?,效率也不高?SQL Server專門為這些操作提供了新的功能,允許高效地導入和導出大量數(shù)據(jù),同時將資源的消耗降至最低。第第7章章 數(shù)據(jù)的導入和導出數(shù)據(jù)的導入和導出兩年前,我合作過的一個企業(yè)有一個完整的分公司專門負責為合作伙伴履行訂單。合作伙伴每天都將訂單文件上傳到FTP服務(wù)器。這些文件會被解析并加載到數(shù)據(jù)庫,然后通過一系列出貨、打包、發(fā)貨
2、和結(jié)帳過程進行處理。遺憾的是,導入每個合作伙伴的訂單往往都要花上2-7個小時。但為了滿足和客戶的協(xié)議,要求所有合作伙伴的文件都必須在1小時內(nèi)導入完成。一個文件夾中往往會有30或更多的文件等待處理。除此之外,只有5%的合作伙伴才允許批量上傳訂單,因為系統(tǒng)處理不了任何額外的負載。用于導入訂單的系統(tǒng)由十幾C+應(yīng)用程序構(gòu)成,30多個文件夾散布在3臺服務(wù)器上,在導入訂單的數(shù)據(jù)庫中,只存在有少量代碼。這些程序是十幾年前寫的,它們90%惟上的工作都是在不同的目錄之間移動文件,而目錄唯一的作用就是在處理期間隔離文件。通過進一步研究,我們還發(fā)現(xiàn)對多個應(yīng)用程序進行管理的代碼試圖訪問相同的文件。這所以出現(xiàn)這個現(xiàn)象,
3、完全是整個系統(tǒng)的組合方式造成的。文件終于各就各位并開始真正進行和業(yè)務(wù)有關(guān)的處理時,我們發(fā)現(xiàn)應(yīng)用程序每次從文件中讀取一行并處理它。針對處理的每一行,應(yīng)用程序都執(zhí)行超過100個查詢來校驗產(chǎn)品代碼、現(xiàn)有庫存、價格水平以及其他幾個業(yè)務(wù)規(guī)則。我們重寫整個系統(tǒng)來利用SQL Server的批量導入功能。在重寫的階段1,我們刪除了所有的C+代碼和整個文件夾結(jié)構(gòu),用單個文件夾來取而代之,用一個存儲過程對文件進行BCP,并用另一個存儲過程處理文件導入之后的一切事情。在階段2,我們將BCP例程替換成一個SSIS包,它能并行處理多個文件,而且在處理多種數(shù)據(jù)格式時更靈活。完成階段1后,導入例程的效率已遠遠地超出合作伙伴
4、上傳文件的速度。文件上傳之后不到一分鐘的時間,所有數(shù)據(jù)便已導入并處理完成,訂單在倉庫那里排隊等待打包。完成階段2后,我們將訂單上傳服務(wù)擴展到其他95%的合作伙伴。甚至最大的合作伙伴的訂單文件也能在文件上傳之后的15秒內(nèi)處理完畢。系統(tǒng)升級改造的直接結(jié)果是有利于擴大客戶群。在新系統(tǒng)改造完畢之后的半年之內(nèi),公司的業(yè)務(wù)增長超過400%以上。實例回放實例回放1. 導入和導出數(shù)據(jù)學習目標 使用BCP(bulk copy program)將數(shù)據(jù)導出到文件 使用BCP從文件導入數(shù)據(jù) 使用BULK INSERT從文件導入數(shù)據(jù) 使用“SQL Server導入導出向?qū)А边M行數(shù)據(jù)導入和導出1. 導入和導出數(shù)據(jù)批量復制
5、程序(BCP) BCP是將文件中的具有一定格式的數(shù)據(jù)導入SQL Server以及將表導出到文件最有效的方式。 BCP設(shè)計成導入和導出數(shù)據(jù)的一種非常快的、輕量級的解決方案。 若要在導入/導出過程中執(zhí)行轉(zhuǎn)換,或者執(zhí)行錯誤處理例程,那么應(yīng)該使用SQLServer Integration Services(SSIS)來進行導入/導出。 使用BCP導出數(shù)據(jù),運行BCP的帳戶只需要表或視圖上的SELECT權(quán)限。導入數(shù)據(jù),需要SELECT, INSERT和ALTER TABLE權(quán)限。1. 導入和導出數(shù)據(jù)BCP是從命令行執(zhí)行的實用程序,語法如下:bcp database_name.owner.table_na
6、me | view_name | query in | out | queryout | format data_file -m max_errors -f format_file -e err_file -F first_row -L last_row -b batch_size -n -c -w -N -V (60 | 65 | 70) -6 -q -C code_page -t field_term -r row_term -i input_file -o output_file -a packet_size -S server_nameinstance_name -U login_id
7、 -P password -T -v -R -k -E -h hint ,.n 警告:大小寫敏感SQL Server數(shù)據(jù)導入導出工具數(shù)據(jù)導入導出工具BCP詳解詳解http:/ 導入和導出數(shù)據(jù)示例bcp AdventureWorks.HumanResources.Department out c:testdepartment.txt n SHOTEK Tbcp AdventureWorks.HumanResources.Department in c:testdepartment.txt c SHOTEK U -Pbcp “SELECT Name, GroupName FROM HumanRes
8、ources.Department” queryout c:testdepartment.txt n SHOTEK -T說明:-n c參數(shù)互斥-n 使用數(shù)據(jù)的本機(數(shù)據(jù)庫)數(shù)據(jù)類型執(zhí)行大容量復制操作。此選項不提示輸入每一字段,它將使用本機值。-c 使用字符數(shù)據(jù)類型執(zhí)行大容量復制操作。此選項不提示輸入每一字段;它使用 char 作為存儲類型,不帶前綴,t(制表符)作為字段分隔符,n(換行符)作為行終止符。-S 開關(guān)指定要連接到的實例名稱。-T 開關(guān)指定一個可信的連接,將用執(zhí)行BCP時使用的Windows賬戶建立連接。-U P 可使用SQL Server登錄憑據(jù)。1. 導入和導出數(shù)據(jù)注意強制檢查約
9、束和觸發(fā)器強制檢查約束和觸發(fā)器用BCP將數(shù)據(jù)導入表時,觸發(fā)器和檢查約束默認禁用。如果想強制檢查約束,并在導入期間激活觸發(fā)器,需要使用-h開關(guān)。如果導入時不禁用觸發(fā)器和檢查約束,就不需要ALTER TABLE權(quán)限。1. 導入和導出數(shù)據(jù)BULK INSERT命令BCP實用程序的缺點在于它是一個命令行程序。BULK INSERT命令提供了許多和BCP相同的選項,行為也基本相同,但存在以下2個區(qū)別: BULK INSERT不能導出數(shù)據(jù) BULK INSERT是T-SQL命令,不需要指定實例名或登錄憑據(jù)。BULK INSERT 詳解http:/ 導入和導出數(shù)據(jù)SQL Server導入和導出向?qū) BCP
10、和BULK INSERT命令提供了簡單 、輕量級的方式,通過使用文件來導入和導出數(shù)據(jù)。n 若想直接在來源和目的地之間導入和導出數(shù)據(jù),同時應(yīng)用轉(zhuǎn)換和錯誤處理例程,則可以使用SQL Server Intergration Service(SSIS)的功能來構(gòu)建。n SSMS中的“SQL Server導入和導出向?qū)А碧峁┝薙SIS功能的一個子集,允許管理員在來源和目的地之間移動數(shù)據(jù)。n 向?qū)褂肧SIS能識別的任何數(shù)據(jù)源,包括EXCEL,ACCESS或者XML文件。n 向?qū)еС諳LEDB數(shù)據(jù)提供程序的任何數(shù)據(jù)源或目的地。n 向?qū)Р灰髷?shù)據(jù)源或目的地是SQLServer實例。n 向?qū)Э蓮亩鄠€表或文件移
11、動數(shù)據(jù);BCP和BULK INSERT只能操作單個表、視圖或查詢。實訓1 使用BCP導入和導出數(shù)據(jù)1.打開命令提示符窗口執(zhí)行以下命令bcp AdventureWorks.HumanResources.Department out c:testdepartment.txt c S -T2.在記事本中打開department.txt文件查看文件內(nèi)容3.執(zhí)行以下命令bcp AdventureWorks.HumanResources.Department out c:testdepartment.txt n S -T4.查看導出文件內(nèi)容。實訓2 練習使用向?qū)牒蛯С鰯?shù)據(jù)將AdventureWorks數(shù)據(jù)庫中的數(shù)據(jù)導出至一個EXCEL文件中本章回顧n BCP程序允許將數(shù)據(jù)從文件導入表,或者將數(shù)據(jù)從表導出到文件。n BULK INSERT是一個T-SQL命令,允許將數(shù)據(jù)從文件導入表。n “導入和導出向?qū)А笔褂肧SIS的一個子集在數(shù)
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 安徽省阜陽市太和縣2023-2024學年八年級下學期4月期中物理試題【含答案、解析】
- 2025年粵教滬科版八年級地理下冊月考試卷含答案
- 2025年粵教新版選擇性必修2地理下冊階段測試試卷含答案
- 2025年粵人版必修1歷史上冊階段測試試卷
- 2025年蘇人新版九年級生物下冊月考試卷含答案
- 2025年粵人版七年級語文上冊階段測試試卷
- 2025年湘教版九年級生物上冊階段測試試卷
- 2025年新世紀版八年級地理上冊階段測試試卷含答案
- 2025年滬科版選擇性必修3歷史上冊月考試卷含答案
- 公司財務(wù)知到智慧樹章節(jié)測試課后答案2024年秋北京第二外國語學院
- 化學-河南省TOP二十名校2025屆高三調(diào)研考試(三)試題和答案
- 智慧農(nóng)貿(mào)批發(fā)市場平臺規(guī)劃建設(shè)方案
- 林下野雞養(yǎng)殖建設(shè)項目可行性研究報告
- 2023年水利部黃河水利委員會招聘考試真題
- Python編程基礎(chǔ)(項目式微課版)教案22
- 01J925-1壓型鋼板、夾芯板屋面及墻體建筑構(gòu)造
- 欠電費合同范本
- 2024年新高考地區(qū)數(shù)學選擇題填空壓軸題匯編十八含解析
- 網(wǎng)易云音樂用戶情感畫像研究
- 小學四年級奧數(shù)題平均數(shù)問題習題及答案
- 工作違紀違規(guī)檢討書范文
評論
0/150
提交評論