1. 程式人生 > >SQL Server BCP 資料導入導出

SQL Server BCP 資料導入導出

nag 視圖 之間 lac _id 控制 參數 har tle

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的用戶名,用戶名直接與參數之間不要有空格,否則會報錯

如用戶名:Fred, 正確的格式為:-Ufred

-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" -Usa -Ppassword

對要導出的表進行過濾。

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‘

SQL Server BCP 資料導入導出