大容量csv快速內(nèi)導(dǎo)入sqlserver的解決方法(推薦)
前言
在論壇中回答了一個問題,導(dǎo)入csv 數(shù)據(jù),并對導(dǎo)入的數(shù)據(jù)增加一個新的列date datetime。要求在10s內(nèi)完成,200w行數(shù)據(jù)的導(dǎo)入.分享下解決問題的思路和方法
分析
通常來講Bulk insert 比 BCP 更快一點,我們選擇Bulk insert的方式。 提出的解決方案:先把數(shù)據(jù)導(dǎo)入到sql server 的臨時表,然后再插入目標(biāo)表。 具體語句如下:
bulk insert test07232 from 'D:\2017-7-22.csv' WITH ( FIELDTERMINATOR = ',', ROWTERMINATOR = '/n' ) SELECT * ,GETDATE() AS Date INTO ttt FROM test07232
但是他提供的的csv 進(jìn)行導(dǎo)入時,提示如下錯誤
消息 4866,級別 16,狀態(tài) 1,第 1 行 大容量加載失敗。數(shù)據(jù)文件中第 1 行的第 2 列太長。請驗證是否正確指定了字段終止符和行終止符。 消息 7399,級別 16,狀態(tài) 1,第 1 行 鏈接服務(wù)器 "(null)" 的 OLE DB 訪問接口 "BULK" 報錯。提供程序未給出有關(guān)錯誤的任何信息。
消息 7330,級別 16,狀態(tài) 2,第 1 行 無法從鏈接服務(wù)器 "(null)" 的 OLE DB 訪問接口"BULK"提取行。
這是由于行終止符無法識別導(dǎo)致的。使用notepad++打開csv文件,在視圖中選擇顯示行尾號。
可以看到文件的換行符是LF
而對于正常的csv問題 默認(rèn)是用CRLF作為換行符的
因此上面的bulk insert 語句無法正常執(zhí)行。
解決
1.首先想到的是修改數(shù)據(jù)源頭,讓源頭產(chǎn)生正常的數(shù)據(jù),但是源頭數(shù)據(jù)不好修改 2.用程序,寫c#處理,,太費時間 3.最后終于找到了正確的辦法
bulk insert test07232 from 'D:\2017-7-22.csv' WITH ( FIELDTERMINATOR = ',', ROWTERMINATOR = '0x0a' ) SELECT * ,GETDATE() AS Date INTO ttt FROM test07232
最后全部都在SSD 上,導(dǎo)入用時2s。生產(chǎn)正式表1s 。整個過程3s完成。
總結(jié)
解決問題要從各個問題入手,找到原因才更好的解決問題
總結(jié)
以上所述是小編給大家介紹的大容量csv快速內(nèi)導(dǎo)入sqlserver的解決方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
教你恢復(fù)SQLSERVER的master系統(tǒng)庫的方法
這篇文章主要介紹了恢復(fù)SQLSERVER的master系統(tǒng)庫,本文介紹可能需要恢復(fù)master數(shù)據(jù)庫的情況以及如何正確完成這些步驟,需要的朋友可以參考下2022-09-09
SQL?Server使用SELECT?INTO實現(xiàn)表備份的代碼示例
在數(shù)據(jù)庫管理過程中,有時我們需要對表進(jìn)行備份,以防數(shù)據(jù)丟失或修改錯誤,在?SQL?Server?中,可以使用?SELECT?INTO?語句將數(shù)據(jù)從一個表備份到另一個表,本文通過代碼示例介紹的非常詳細(xì),需要的朋友可以參考下2025-01-01
Sql學(xué)習(xí)第一天——SQL UNION 和 UNION ALL 操作符認(rèn)識
UNION 操作符用于合并兩個或多個 SELECT 語句的結(jié)果集,有一點需要注意的是UNION 內(nèi)部的 SELECT 語句必須擁有相同數(shù)量的列,接下來為大家詳細(xì)介紹下,感興趣的各位可以參考下哈2013-03-03
不同數(shù)據(jù)庫之間導(dǎo)入導(dǎo)出功能介紹
在SQL Server中使用最廣泛的就是通過SELECT INTO語句導(dǎo)出數(shù)據(jù),SELECT INTO語句同時具備兩個功能2010-12-12
SQL?Server修改數(shù)據(jù)的幾種語句詳解
在SQL中的基本操作就是增刪改查,查詢語句不會對數(shù)據(jù)庫中的數(shù)據(jù)進(jìn)行修改,下面這篇文章主要給大家介紹了關(guān)于SQL?Server修改數(shù)據(jù)的幾種語句,需要的朋友可以參考下2022-10-10
關(guān)于SQL中CTE(公用表表達(dá)式)(Common Table Expression)的總結(jié)
WITH AS短語,也叫做子查詢部分(subquery factoring),可以讓你做很多事情,定義一個SQL片斷,該SQL片斷會被整個SQL語句所用到2012-08-08

