您目前已離線,請等候您的網際網路重新連線

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

Office 2003 支援已結束

Microsoft 於 2014 年 4 月 8 日結束對 Office 2003 的支援。此變更已影響您的軟體更新和安全性選項。 瞭解這對您的意義為何且如何持續受保護。

重要:本文是以 Microsoft 機器翻譯軟體翻譯而成,而非使用人工翻譯而成。Microsoft 同時提供使用者人工翻譯及機器翻譯兩個版本的文章,讓使用者可以依其使用語言使用知識庫中的所有文章。但是,機器翻譯的文章可能不盡完美。這些文章中也可能出現拼字、語意或文法上的錯誤,就像外國人在使用本國語言時可能發生的錯誤。Microsoft 不為內容的翻譯錯誤或客戶對該內容的使用所產生的任何錯誤或損害負責。Microsoft也同時將不斷地就機器翻譯軟體進行更新。

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.dblTestFROM tblExample;				
dblTest 是與雙精準數資料類型欄位的位置。將 dblTest 轉換為 String 資料型別中,SQL 語法來進行下列變更:
SELECT tblExample.pkeyDataID, CStr([dblTest]) AS Expr1FROM tblExample;				
查詢可以現在能成功匯出至 Oracle。

解決這個問題,Microsoft Jet 4.0 資料庫引擎服務套件 8 (SP8) 中。如需有關 Microsoft Jet 4.0 資料庫引擎 SP8,按一下 [下面的文件編號,檢視 「 Microsoft 知識庫 」 中的發行項]:
829558Jet 4.0 Service Pack 8 的相關資訊
狀況說明
Microsoft 已確認這是在本文開頭所列之 Microsoft 產品中的問題。
其他相關資訊
本文中討論的協力廠商產品是由與 Microsoft 無關的公司所製造。Microsoft 可讓不以暗示或其他方式,效能或可靠性這些產品的保證。
pra Oracle varchar2 DoCmd.TransferDatabase 方法失敗 ACC2002 ACC2000 ACC2003 ACC2007

警告:本文已自動翻譯

內容

文章識別碼:301915 - 最後檢閱時間:03/26/2007 23:26:32 - 修訂: 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
意見反應