當您匯出欄位的資料型別單引號或雙引號 Oracle 存取會造成錯誤

文章翻譯 文章翻譯
文章編號: 301915 - 檢視此文章適用的產品。
中級使用者: 需要基本巨集]、 [程式碼撰寫,] 以及 [交互操作性技巧。

本文可套用於 [Microsoft Access 資料庫 (.mdb) 和 Microsoft Access 專案 (.adp)。

全部展開 | 全部摺疊

徵狀

當您使用 Oracle ODBC 驅動程式來匯出的存取有單一的資料型別或是 Double,驅動程式的欄位的資料表失敗匯出那些欄位,如下所示。
Microsoft Oracle 驅動程式會顯示下列錯誤訊息:
Microsoft Access 無法附加所有資料至資料表。

已刪除 <number>個記錄中的欄位的內容,而且 0 記錄已遺失,因為索引鍵衝突。
  • 如果刪除的資料貼上或匯入的資料不符欄位資料類型或目的資料表中的 [欄位大小] 屬性。
  • 如果記錄已遺失可能是您所貼上的記錄包含已存在於目的] 資料表的主索引值或違反參考完整性規則定義資料表之間的關聯性。
    您要繼續嗎?
最多的 Oracle ODBC 驅動程式,以及 8.1.6 顯示下列錯誤訊息的包括版本:
ODBC-呼叫失敗
[先知][ODBC][ORA]ORA-01401: 插入對資料行而言太大的值 (# 1401)

發生的原因

在 Microsoft Access 97 中匯出處理序會以 VarChar2(40) 轉換 [單精準數] 和 [雙精準數] 資料類型欄位。不過,在 Microsoft Access 2000 及更新版本中,欄位將會轉換成 VarChar2(4),哪些它太小,以容納資料。

解決方案

若要成功地將資料匯出至 Oracle,使用相關的資料表為基礎的查詢。使用 CStr() 函數來轉換為 String 資料型別。

例如,請考慮下列的 SQL 語法:
SELECT tblExample.pkeyDataID, tblExample.dblTest
FROM tblExample;
				
dblTest 是與雙精準數資料類型欄位的位置。將 dblTest 轉換為 String 資料型別中,SQL 語法來進行下列變更:
SELECT tblExample.pkeyDataID, CStr([dblTest]) AS Expr1
FROM tblExample;
				
查詢可以現在能成功匯出至 Oracle。

解決這個問題,Microsoft Jet 4.0 資料庫引擎服務套件 8 (SP8) 中。如需有關 Microsoft Jet 4.0 資料庫引擎 SP8,按一下 [下面的文件編號,檢視 「 Microsoft 知識庫 」 中的發行項]:
829558Jet 4.0 Service Pack 8 的相關資訊

狀況說明

Microsoft 已確認這是在本文開頭所列之 Microsoft 產品中的問題。

其他相關資訊

本文中討論的協力廠商產品是由與 Microsoft 無關的公司所製造。Microsoft 可讓不以暗示或其他方式,效能或可靠性這些產品的保證。

屬性

文章編號: 301915 - 上次校閱: 2007年3月26日 - 版次: 5.1
這篇文章中的資訊適用於:
  • Microsoft Office Access 2007
  • Microsoft Office Access 2003
  • Microsoft Access 2002 Standard Edition
  • Microsoft Access 2000 Standard Edition
關鍵字:?
kbmt kbexport kbbug kberrmsg kbnofix KB301915 KbMtzh
機器翻譯
重要:本文是以 Microsoft 機器翻譯軟體翻譯而成,而非使用人工翻譯而成。Microsoft 同時提供使用者人工翻譯及機器翻譯兩個版本的文章,讓使用者可以依其使用語言使用知識庫中的所有文章。但是,機器翻譯的文章可能不盡完美。這些文章中也可能出現拼字、語意或文法上的錯誤,就像外國人在使用本國語言時可能發生的錯誤。Microsoft 不為內容的翻譯錯誤或客戶對該內容的使用所產生的任何錯誤或損害負責。Microsoft也同時將不斷地就機器翻譯軟體進行更新。
按一下這裡查看此文章的英文版本:301915
Microsoft及(或)其供應商不就任何在本伺服器上發表的文字資料及其相關圖表資訊的恰當性作任何承諾。所有文字資料及其相關圖表均以「現狀」供應,不負任何擔保責任。Microsoft及(或)其供應商謹此聲明,不負任何對與此資訊有關之擔保責任,包括關於適售性、適用於某一特定用途、權利或不侵權的明示或默示擔保責任。Microsoft及(或)其供應商無論如何不對因或與使用本伺服器上資訊或與資訊的實行有關而引起的契約、過失或其他侵權行為之訴訟中的特別的、間接的、衍生性的損害或任何因使用而喪失所導致的之損害、資料或利潤負任何責任。

提供意見

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com