批量导入数据到mssql数据库的
概述
批量導(dǎo)入數(shù)據(jù)到數(shù)據(jù)庫中,我們有好幾種方式。
上面兩種方式,導(dǎo)入的數(shù)據(jù)都會(huì)生成大量的日志。如果批量導(dǎo)入5W條數(shù)據(jù)到數(shù)據(jù)表里,就有生成5W條insert日志。那么這有好的方式處理這個(gè)問題嗎?
下面介紹另一種導(dǎo)入方式,批處理導(dǎo)入。
批處理導(dǎo)入數(shù)據(jù)
步驟一
準(zhǔn)備一個(gè)空的數(shù)據(jù)表Table,將你要導(dǎo)入的數(shù)據(jù),全部導(dǎo)入到這個(gè)Table里,當(dāng)然,這個(gè)數(shù)據(jù)表Table和你要導(dǎo)入的表結(jié)構(gòu)是一模一樣的。之后新建一個(gè)記事本,里面寫上如下的批處理命令,保存命名為import.bat
bcp [Test].dbo.Table OUT "d:/test.txt" -c -S 192.168.1.1 -U sa -P 123456pause上面的命令-U -S -T分別是什么意思,見后文。當(dāng)前,如果你的數(shù)據(jù)庫身份驗(yàn)證是windows,如果寫成
bcp [Test].dbo.Table OUT "d:/test.txt" -c -S 192.168.1.1 -T pause執(zhí)行命令后,將得到一個(gè)記錄得Table所有數(shù)據(jù)的test.txt文件。
步驟二
新建一個(gè)記事本,里面寫批處理命令,將所有的數(shù)據(jù)都導(dǎo)入到指定的數(shù)據(jù)庫表里
bcp "[Test].dbo.Table" in "d:/test.txt" -c -S (local) -U sa -P 123456pause數(shù)據(jù)庫身份驗(yàn)證是windows,寫成
bcp "[Test].dbo.Table" in "d:/test.txt" -c -S (local) -Tpausebcp批處理命名解釋
[Test].dbo.Table:數(shù)據(jù)庫表名
d:/test.txt :要導(dǎo)入的數(shù)據(jù)
-S ?server_name[?\instance_name] ,后面填的是服務(wù)器,上面是 (local),當(dāng)然,填 . 也行
-U login_id,后面指的是服務(wù)器登陸用戶名
-P password,后面指的是服務(wù)器登陸密碼
-T 指定?bcp?實(shí)用工具通過使用集成安全性的可信連接連接到 SQL Server。不需要網(wǎng)絡(luò)用戶的安全憑據(jù)、login_id?和?password。如果不指定?–T,則需要指定?–U?和?–P?才能成功登錄
解釋完上面之后,接下來解釋一下d:/test.txt
這個(gè)文本里的數(shù)據(jù)是有格式的,數(shù)據(jù)表里有多少個(gè)字段,這里面就應(yīng)該有多少字段,每個(gè)字段對應(yīng)著數(shù)據(jù)表里的字段,中間用Tab鍵隔開。例如:
51006?? ?NULL?? ?bbbbbbbbbbbbbbB?? ?2015-12-31 00:00:00.000?? ?0?? ?NULL?? ?1.00000?? ?2?? ?1?? ?2015-02-09 12:08:28.017?? ?jys?? ?2015-02-09 12:08:28.017?? ?jys?? ?0
51007?? ?NULL?? ?aaaaaaaaaaaaaaB?? ?2015-12-31 00:00:00.000?? ?0?? ?NULL?? ?1.00000?? ?2?? ?1?? ?2015-02-09 12:08:28.017?? ?jys?? ?2015-02-09 12:08:28.017?? ?jys?? ?0
51008?? ?NULL?? ?ccccccccccccccB?? ?2015-12-31 00:00:00.000?? ?0?? ?NULL?? ?1.00000?? ?2?? ?1?? ?2015-02-09 12:08:28.017?? ?jys?? ?2015-02-09 12:08:28.017?? ?jys?? ?0
如果第一列是自增ID,你填寫的數(shù)值無效的,數(shù)據(jù)庫會(huì)自動(dòng)自增。
結(jié)果
最后,執(zhí)行批處理文件命令即可,這樣,導(dǎo)入數(shù)據(jù)生成的日志只有一條。
?
總結(jié)
以上是生活随笔為你收集整理的批量导入数据到mssql数据库的的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 说不出的压抑和心累的句子130个
- 下一篇: MySQL 关闭子表的外键约束检察