如何使用SQLServer命令BCP導入導出EXCEL數據?
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 -Tbcp 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 -Tbcp 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'