開発Blog

最近のトラブル事例から - Oracle11でDATE型が正しく表示できない –

投稿日:2010-05-06 更新日:

毎年、4月になると、年度末で開発を終えたシステムが運用を開始して、さまざまなお問い合わせがくる季節で、今年も、例年と同じく、さまざまなご相談を弊社サポートサイトを中心に対応させていただきました。そこで、いくつかご紹介します。

■トラブル事象:
Oracle11.1を利用していて、ViewCreaterでDATE型のデータを表示すると正しく表示できない。

本件は、以下の原因で発生した問題です。

Oracle Database10gまでは、JDBCドライバがoracle.sql.DATEをjava.sql.Dateにマッピングしていましたが、Oracle Database 11.1では、新しいフラグmapDateToTimestampが導入され、デフォルトで、JDBCドライバがoracle.sql.DATEをjava.sql.Timestampにマッピングするようになった結果、DBからデータを取得した後、文字列型として値を返却しているため発生した問題です。

「参考資料」
http://otndnld.oracle.co.jp/document/products/oracle11g/111/doc_dvd/java.111/E05720-02/apxref.htm
のOracleオブジェクト型からSQL DATEデータ型へのマッピングを参考してください。

対策1:設定で、Oracle10g以前と同じ動きにする。

.JVMの起動パラメタとして次の値を設定する必要があります。

-Doracle.jdbc.mapDateToTimestamp=false
⇒oracle.sql.DATEをjava.sql.Dateにマッピングして10gと同じ動きをさせる。

対策2:intra-mart側でjava.sql.Timestamp型を日付型として認識させる。

imart.xmlのtimestamp-is-dateの設定値をtrueに変更する。
→java.sql.Timestamp型を文字列ではなく日付型として認識させる。

※Service Platform 設定ガイドの4.1.2.15 intra-mart/platform/service/application/database/data/timestamp-is-dateを参考してください。

※対策2はお客様の運用方針によってアプリケーションに影響を及ぼす可能性があるため、対策1の方法を推奨します。

既存のシステムでは、起きないトラブルですが、今後の新規導入時やVerUp時などで、以外とはまりやすい点だと思いますので、ご注意ください。

-開発Blog
-

執筆者:


comment

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です

関連記事

no image

トラブル時の現状把握に必要な情報

※下記内容は、過去のintra-mart(Ver4.3以前)に関する内容です。 最新のintra-martでは、異なる情報であることがありますので、ご注意ください。 大規模システムが増加するに従い、弊 …

no image

ワークフロー案件退避ツール

こんにちは、開発本部の大西です。 最近、ワークフローモジュールを利用しているユーザ様で、ワークフローの未処理案件一覧や起票済案件一覧の表示が遅くなったというご意見を多数を伺っております。 現行のワーク …

no image

Win7(64bit)上で e Builder Ver.7.2 を使用するには…

Windows 7 (64bit) 上で e Builder Ver.7.2 を使用するには現状、 「-d32オプションをeclipse.iniのvmargsに追加する」 方法しかございません。。 [ …

no image

intra-mart WebPlatform/AppFramework Ver7.2について その3

では、第3回、アクセスセキュリティ関連とポータルの機能追加をご紹介します。 ■アクセスセキュリティ 1. ログイングループ単位でアプリケーションロール数が設定可能になりました。 イントラネット・スター …

no image

1pxへのこだわり♪

IM-FormaDesignerでは、Webブラウザ上でアプリを作ることができます。 まもなくリリース予定のパッチ2では、フォーム・デザイナに関して以下の3つの改善と修正を行います。 要件 [1679 …

まだデータがありません。

RSSRSSRSSRSS