Excel導(dǎo)入數(shù)據(jù)庫(kù)時(shí)出現(xiàn)的文本截?cái)鄦?wèn)題解決方案
在把Excel導(dǎo)入到數(shù)據(jù)庫(kù)中時(shí),發(fā)生文本截?cái)鄦?wèn)題:即導(dǎo)入的數(shù)據(jù)每行只有一部分,原始的Excel數(shù)據(jù)為:

忽略錯(cuò)誤
導(dǎo)入SQLServer2008過(guò)程中,如果源數(shù)據(jù)和目標(biāo)數(shù)據(jù)類(lèi)型不匹配會(huì)導(dǎo)入失敗,所以導(dǎo)入數(shù)據(jù)時(shí)會(huì)忽略錯(cuò)誤,這次導(dǎo)入題庫(kù)也是,結(jié)果出現(xiàn)了這樣的問(wèn)題:

仔細(xì)觀察你會(huì)發(fā)現(xiàn),題目不完整,最長(zhǎng)為25個(gè)漢字,很明顯這是varchar(50)數(shù)據(jù)類(lèi)型,但是源數(shù)據(jù)和目的數(shù)據(jù)明明都為文本類(lèi)型。
不忽略錯(cuò)誤
如果不忽略錯(cuò)誤,導(dǎo)入數(shù)據(jù)最后一步會(huì)產(chǎn)生這樣的問(wèn)題:
-正在執(zhí)行(錯(cuò)誤)
消息
錯(cuò)誤0xc02020c5:數(shù)據(jù)流任務(wù)1:在將列“questionContent”(33)轉(zhuǎn)換為列“questionContent”(119)時(shí)數(shù)據(jù)轉(zhuǎn)換失敗。轉(zhuǎn)換操作返回狀態(tài)值4和狀態(tài)文本“文本被截?cái)?,或者一個(gè)或多個(gè)字符在目標(biāo)代碼頁(yè)中沒(méi)有匹配項(xiàng)?!?。
(SQLServer導(dǎo)入和導(dǎo)出向?qū)?
錯(cuò)誤0xc020902a:數(shù)據(jù)流任務(wù)1:“輸出列“questionContent”(119)”由于發(fā)生截?cái)喽。裔槍?duì)“輸出列“questionContent”(119)”的截?cái)嘈刑幚碓O(shè)置指定截?cái)鄷r(shí)出錯(cuò)。在指定組件的指定對(duì)象上出現(xiàn)截?cái)噱e(cuò)誤。
(SQLServer導(dǎo)入和導(dǎo)出向?qū)?
錯(cuò)誤0xc0047022:數(shù)據(jù)流任務(wù)1:SSIS錯(cuò)誤代碼DTS_E_PROCESSINPUTFAILED。處理輸入“數(shù)據(jù)轉(zhuǎn)換輸入”(92)時(shí),組件“數(shù)據(jù)轉(zhuǎn)換0-0”(91)的ProcessInput方法失敗,錯(cuò)誤代碼為0xC020902A。標(biāo)識(shí)的這個(gè)組件從ProcessInput方法返回了一個(gè)錯(cuò)誤。雖然該錯(cuò)誤是此組件特有的,但卻是致命的,將導(dǎo)致數(shù)據(jù)流任務(wù)停止運(yùn)行??赡茉诖酥耙呀?jīng)發(fā)出錯(cuò)誤消息,提供了有關(guān)失敗的詳細(xì)信息。
(SQLServer導(dǎo)入和導(dǎo)出向?qū)?
解決方法
SQL語(yǔ)句
可以確定這個(gè)問(wèn)題不是由數(shù)據(jù)類(lèi)型不匹配引起,如何解決?既然通過(guò)界面方法不能完整導(dǎo)入,可以采用SQL語(yǔ)句的方式再試試:
SELECT*INTO[MaKeSiExam].[dbo].[t_makesi_duoxuanti1]FROMOPENDATASOURCE('Microsoft.Jet.OLEDB.4.0',
'DataSource=D:/考試系統(tǒng)/題庫(kù)/2012年下半年馬克思考試/馬克思_多選題.xls;
ExtendedProperties=Excel8.0')...[Sheet1$]
前提
使用SQL語(yǔ)句的方法可能會(huì)產(chǎn)生兩個(gè)錯(cuò)誤:
SQLServer阻止了對(duì)組件'AdHocDistributedQueries'的STATEMENT'OpenRowset/OpenDatasource'的訪問(wèn),因?yàn)榇私M件已作為此服務(wù)器安全配置的一部分而被關(guān)閉
消息7399,級(jí)別16,狀態(tài)1,第1行
鏈接服務(wù)器"(null)"的OLEDB訪問(wèn)接口"Microsoft.Jet.OLEDB.4.0"報(bào)錯(cuò)。提供程序未給出有關(guān)錯(cuò)誤的任何信息。
消息7303,級(jí)別16,狀態(tài)1,第1行
無(wú)法初始化鏈接服務(wù)器"(null)"的OLEDB訪問(wèn)接口"Microsoft.Jet.OLEDB.4.0"的數(shù)據(jù)源對(duì)象。
解決方法
--啟用AdHocDistributedQueries
execsp_configure'showadvancedoptions',1
reconfigure
execsp_configure'AdHocDistributedQueries',1
reconfigure
第二個(gè)問(wèn)題,是因?yàn)镋xcel文件和SQLServer沒(méi)在同一臺(tái)機(jī)器,把Excel放到數(shù)據(jù)庫(kù)所在機(jī)器上執(zhí)行上述SQL語(yǔ)句即可,注意以上導(dǎo)入數(shù)據(jù)庫(kù)的語(yǔ)句需要自建表,表字段數(shù)據(jù)類(lèi)型為Excel中的數(shù)據(jù)類(lèi)型。
導(dǎo)入完畢,可再關(guān)閉AdHocDistributedQueries
--關(guān)閉AdHocDistributedQueries
execsp_configure'AdHocDistributedQueries',0
reconfigure
execsp_configure'showadvancedoptions',0
reconfigure
導(dǎo)入結(jié)果

- asp實(shí)現(xiàn)excel中的數(shù)據(jù)導(dǎo)入數(shù)據(jù)庫(kù)
- PHP將Excel導(dǎo)入數(shù)據(jù)庫(kù)及數(shù)據(jù)庫(kù)數(shù)據(jù)導(dǎo)出至Excel的方法
- Drupal讀取Excel并導(dǎo)入數(shù)據(jù)庫(kù)實(shí)例
- 利用phpexcel把excel導(dǎo)入數(shù)據(jù)庫(kù)和數(shù)據(jù)庫(kù)導(dǎo)出excel實(shí)現(xiàn)
- PHP 如何利用phpexcel導(dǎo)入數(shù)據(jù)庫(kù)
- ASP.NET下將Excel表格中的數(shù)據(jù)規(guī)則的導(dǎo)入數(shù)據(jù)庫(kù)思路分析及實(shí)現(xiàn)
- C++ 中實(shí)現(xiàn)把EXCEL的數(shù)據(jù)導(dǎo)入數(shù)據(jù)庫(kù)(ACCESS、MSSQL等)實(shí)例代碼
相關(guān)文章
Microsoft SQL Server 2008安裝圖解教程(Windows 7)
本文詳細(xì)介紹了SQL Server 2008的完整安裝過(guò)程,但未介紹關(guān)于SP1補(bǔ)丁安裝說(shuō)明,在Windows 7系統(tǒng)上運(yùn)行必須安裝此補(bǔ)丁,對(duì)于部分服務(wù)的配置也未做詳細(xì)的介紹2012-07-07SQL Server 2008數(shù)據(jù)庫(kù)誤刪數(shù)據(jù)如何進(jìn)行數(shù)據(jù)恢復(fù)
這篇文章主要為大家詳細(xì)介紹了SQL Server 2008數(shù)據(jù)庫(kù)誤刪數(shù)據(jù)如何進(jìn)行數(shù)據(jù)恢復(fù)的方法,感興趣的小伙伴們可以參考一下2016-05-05Sql server 2008 express遠(yuǎn)程登錄實(shí)例設(shè)置 圖文教程
Sql server 2008 express遠(yuǎn)程登錄實(shí)例設(shè)置 圖文教程,需要的朋友可以參考下。2011-11-11SQL Server2008 數(shù)據(jù)庫(kù)誤刪除數(shù)據(jù)的恢復(fù)方法分享
今天有個(gè)朋友很著急地打電話給我,他用delete語(yǔ)句誤刪除了SQL Server 2008數(shù)據(jù)庫(kù)中兩個(gè)表中的所有記錄,而這個(gè)數(shù)據(jù)庫(kù)之前沒(méi)有任何備份。讓我?guī)退鉀Q一下,不然他要賠償客戶(hù)很多錢(qián)2011-10-10一個(gè)簡(jiǎn)單的后臺(tái)與數(shù)據(jù)庫(kù)交互的登錄與注冊(cè)[sql注入處理、以及MD5加密]
這篇文章主要介紹了一個(gè)簡(jiǎn)單的后臺(tái)與數(shù)據(jù)庫(kù)交互的登錄與注冊(cè),包含sql注入處理、以及MD5加密知識(shí)點(diǎn)介紹2016-07-07SQL server 2008不允許保存更改的完美解決辦法(圖解)
我重裝系統(tǒng)后就安裝了SQL Server2008R2,第一次使用時(shí)在修改表結(jié)構(gòu)的時(shí)候經(jīng)碰到這樣一個(gè)警告【不允許保存更改。您所做的更改要求刪除并重新創(chuàng)建以下表.對(duì)這樣的錯(cuò)誤提示怎么解決呢?下面小編通過(guò)圖文并茂的形式給大家分享解決辦法2017-01-01sql server 2008安裝失敗的解決辦法 徹底卸載老版本!
這篇文章主要介紹了sql server 2008安裝失敗的解決辦法:徹底卸載老版本!感興趣的小伙伴們可以參考一下2016-08-08sql server 2008 不允許保存更改,您所做的更改要求刪除并重新創(chuàng)建以下表
今天在運(yùn)行sql server 2008時(shí)候提示不允許保存更改,您所做的更改要求刪除并重新創(chuàng)建以下表 的解決辦法2013-05-05SQL Server 2008 數(shù)據(jù)庫(kù)中創(chuàng)建只讀用戶(hù)的方法
這篇文章主要介紹了SQL Server 2008 數(shù)據(jù)庫(kù)中創(chuàng)建只讀用戶(hù)的方法,為了保護(hù)數(shù)據(jù)庫(kù)的安全,需要給不同的使用者開(kāi)通不同的訪問(wèn)用戶(hù),那么如何簡(jiǎn)單的控制用戶(hù)的權(quán)限呢?下面我們就創(chuàng)建一個(gè)只讀用戶(hù),給大家學(xué)習(xí)使用2015-08-08