SQL Server BCP 資料導入導出
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 資料導入導出