単精度浮動小数点型または倍精度浮動小数点型のフィールドを Oracle にエクスポートすると Access でエラーが発生する

文書翻訳 文書翻訳
文書番号: 301915 - 対象製品
難易度 : 中。基本的なマクロ、コーディング、相互運用性に関する知識が必要です。

この資料は Microsoft Access データベース (.mdb) および Microsoft Access プロジェクト (.adp) について記述したものです。

すべて展開する | すべて折りたたむ

現象

Oracle ODBC ドライバを使用して、単精度浮動小数点型または倍精度浮動小数点型のフィールドを持つ Access テーブルをエクスポートするときに、それらのフィールドのエクスポートが失敗し、次の現象が発生します。
Microsoft Oracle ドライバで、次のエラー メッセージが表示されます。
すべてのデータをテーブルに追加できませんでした。

キー違反のため、<number> 件のレコードのデータが失われ、0 件のレコードが削除されました。
  • データが失われたときは、貼り付けまたはインポートしたデータが、対象となるテーブルのフィールドのデータ型または "FieldSize/フィールドサイズ" プロパティと一致していません。
  • レコードが削除されたときは、対象となるテーブルにすでに存在する主キー値が貼り付けたレコードに含まれているか、テーブル間に設定されているリレーションシップの参照整合性に違反しています。
    継続しますか?
バージョン 8.1.6 までの Oracle ODBC ドライバでは、次のエラー メッセージが表示されます。
ODBC - call failed
[Oracle][ODBC][ORA] ORA-01401: Inserted value too large for column (#1401)

原因

Microsoft Access 97 では、エクスポート処理によって単精度浮動小数点型または倍精度浮動小数点型のフィールドが VarChar2(40) に変換されます。しかし、Microsoft Access 2000 およびそれ以降では、データを保持するには小さすぎる VarChar2(4) にフィールドが変換されます。

解決方法

データを Oracle に正常にエクスポートするには、該当するテーブルに基づくクエリを使用します。CStr() 関数を使用して、データ型を文字列に変換します。

たとえば、次の SQL 構文を例に説明します。
SELECT tblExample.pkeyDataID, tblExample.dblTest
FROM tblExample;
				
dblTest は倍精度浮動小数点型のフィールドです。この SQL 構文を次のように変更して、dblTest を文字列型に変換します。
SELECT tblExample.pkeyDataID, CStr([dblTest]) AS Expr1
FROM tblExample;
				
このクエリにより、Oracle に正常にエクスポートできるようになります。

この問題は、Microsoft Jet 4.0 Database Engine Service Pack 8 (SP8) で修正済みです。 Microsoft Jet 4.0 Database Engine SP8 の関連情報を参照するには、以下の「サポート技術情報」 (Microsoft Knowledge Base) をクリックしてください。
829558 [ACC2003] Jet 4.0 Service Pack 8 について

状況

マイクロソフトでは、この問題をこの資料の冒頭に記載したマイクロソフト製品の問題として認識しています。

詳細

この資料に記載されているサードパーティ製品は、マイクロソフトと関連のない他社の製品です。明示または黙示にかかわらず、これらの製品のパフォーマンスや信頼性についてマイクロソフトはいかなる責任も負わないものとします。

プロパティ

文書番号: 301915 - 最終更新日: 2007年5月23日 - リビジョン: 5.1
この資料は以下の製品について記述したものです。
  • Microsoft Office Access 2007
  • Microsoft Office Access 2003
  • Microsoft Access 2002 Standard Edition
  • Microsoft Access 2000 Standard Edition
キーワード:?
kbexport kbbug kberrmsg kbnofix KB301915
"Microsoft Knowledge Baseに含まれている情報は、いかなる保証もない現状ベースで提供されるものです。Microsoft Corporation及びその関連会社は、市場性および特定の目的への適合性を含めて、明示的にも黙示的にも、一切の保証をいたしません。さらに、Microsoft Corporation及びその関連会社は、本文書に含まれている情報の使用及び使用結果につき、正確性、真実性等、いかなる表明・保証も行ないません。Microsoft Corporation、その関連会社及びこれらの権限ある代理人による口頭または書面による一切の情報提供またはアドバイスは、保証を意味するものではなく、かつ上記免責条項の範囲を狭めるものではありません。Microsoft Corporation、その関連会社 及びこれらの者の供給者は、直接的、間接的、偶発的、結果的損害、逸失利益、懲罰的損害、または特別損害を含む全ての損害に対して、状況のいかんを問わず一切責任を負いません。(Microsoft Corporation、その関連会社 またはこれらの者の供給者がかかる損害の発生可能性を了知している場合を含みます。) 結果的損害または偶発的損害に対する責任の免除または制限を認めていない地域においては、上記制限が適用されない場合があります。なお、本文書においては、文書の体裁上の都合により製品名の表記において商標登録表示、その他の商標表示を省略している場合がありますので、予めご了解ください。"

フィードバック

 

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