SQL Server BCP 導入導出使用

   Bcp 導出導入數據高效,比使用SQL Server Management Stdio 提供的數據庫導出導入要高效因爲sql server 也沒有提供提供類似Oracle的expdp和impdp的工具,如果用SQL Server Management Stdio提供的導入導出對大表數據進行遷移速度太慢了

   Bcp 導出數據高效比較適用於大表數據的遷移

進入doc命令行輸入bcp命令,就彈出bcp命令的幫助信息:

C:\Users\wangwei>bcp

    用法: bcp {dbtable | query} {in | out | queryout | format} 數據文件

  [-m 最大錯誤數]             [-f 格式化文件]       [-e 錯誤文件]

  [-F 首行]                   [-L 末行]             [-b 批大小]

  [-n 本機類型]               [-c 字符類型]         [-w 寬字符類型]

  [-N 將非文本保持爲本機類型] [-V 文件格式版本]     [-q 帶引號的標識符]

  [-C 代碼頁說明符]           [-t 字段終止符]       [-r 行終止符]

  [-i 輸入文件]               [-o 輸出文件]         [-a 數據包大小]

  [-S 服務器名稱]             [-U 用戶名]           [-P 密碼]

  [-T 可信連接]               [-v 版本]             [-R 允許使用區域設置]

  [-k 保留 Null 值]           [-E 保留標識值]

  [-h"加載提示"]              [-x 生成 xml 格式化文件]

參數介紹:

bcp共有四個動作可以選擇。

(1) 導入。

這個動作使用in命令完成,後面跟需要導入的文件名。

(2) 導出。

這個動作使用out命令完成,後面跟需要導出的文件名。

(3) 使用SQL語句導出。

這個動作使用queryout命令完成,它跟out類似,只是數據源不是表或視圖名,而是SQL語句。

(4) 導出格式文件。

這個動作使用format命令完成,後而跟格式文件名。

下面介紹一些常用的選項:

-f format_file

format_file表示格式文件名。這個選項依賴於上述的動作,如果使用的是in或out,format_file表示已經存在的格式文件,如果使用的是format則表示是要生成的格式文件。

-x

這個選項要和-f format_file配合使用,以便生成xml格式的格式文件。

-F first_row

指定從被導出表的哪一行導出,或從被導入文件的哪一行導入。

-L last_row

指定被導出表要導到哪一行結束,或從被導入文件導數據時,導到哪一行結束。

-c

使用char類型做爲存儲類型,沒有前綴且以"\t"做爲字段分割符,以"\n"做爲行分割符。

-w

和-c類似,只是當使用Unicode字符集拷貝數據時使用,且以nchar做爲存儲類型。

-t field_term

指定字符分割符,默認是"\t"。

-r row_term

指定行分割符,默認是"\n"。

-S server_name[ \instance_name]

指定要連接的SQL Server服務器的實例,如果未指定此選項,bcp連接本機的SQL Server默認實例。如果要連接某臺機器上的默認實例,只需要指定機器名即可。

-U login_id

指定連接SQL Sever的用戶名。

-P password

指定連接SQL Server的用戶名密碼。

-T

指定bcp使用信任連接登錄SQL Server。如果未指定-T,必須指定-U和-P。

-k

指定空列使用null值插入,而不是這列的默認值。

使用bcp導出數據

在控制檯執行bcp:

bcp db_name.dbo.T_tablename out c:\a.txt -c -T

bcp db_name.dbo.T_tablename out c:\a.txt -c -Uusername -Pxxxxx

通過調用SQL Server的一個系統存儲過程xp_cmdshell以SQL語句的方式運行bcp:

exec master..xp_cmdshell 'bcp db_name.dbo.T_tablename  out c:\a.txt -c -T' --"-T"信任連接

exec master..xp_cmdshell 'bcp db_name.dbo.T_tablename out c:\a.txt -c -Usa -Pxxxxx'

說明:

-T指定 bcp 使用網絡用戶的安全憑據,通過信任連接連接到 SQL Server。不需要 login_id 和 password。

如果不是使用T需要加上-U和-P參數輸入用戶名和密碼

如果是本地導入導出可以不加-S參數,如果連接到遠程服務需要加-S參數

bcp db_name.dbo.tablename out d:\table.txt -c -q -S"120.26.76.220,1833" -U"sa" -P"password"

對要導出的表進行過濾。

bcp不僅可以接受表名或視圖名做爲參數,也可以接受SQL做爲參數,通過SQL語句可以對要導出的表進行過濾,然後導出過濾後的記錄。

EXEC master..xp_cmdshell 'bcp "SELECT TOP 20 * FROM db_name.dbo.T_tablename" queryout c:\table2.txt -c -U"sa" -P"password"'

bcp還可以通過簡單地設置選項對導出的行進行限制。

這條命令使用了兩個參數-F 2和-L 16,表示從SE

EXEC master..xp_cmdshell 'bcp "SELECT TOP 20 * FROM db_name.dbo.T_tablename" queryout c:\currency2.txt -F 2 -L 16 -c -U"sa" -P"password"'

SELECT TOP 20 * FROM db_name.dbo.T_tablename所查出來的結果中取第2條到16條記錄進行導出。

使用bcp導入數據

bcp可以通過in命令將bcp導出的文件導入到表中,首先需要創建表結構和導出數據的表結構相同

在控制檯執行bcp:

bcp db_name.dbo.T_tablename in c:\a.txt-c -T

bcp db_name.dbo.T_tablename in c:\a.txt -c -Uusername -Pxxxxx

通過調用SQL Server的一個系統存儲過程xp_cmdshell以SQL語句的方式運行bcp:

exec master..xp_cmdshell 'bcp db_name.dbo.T_tablename  in c:\a.txt-c -T' --"-T"信任連接

exec master..xp_cmdshell 'bcp db_name.dbo.T_tablename in c:\a.txt -c -Usa -Pxxxxx'

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章