2

次のpersistence.xml構成のejb-jarを想定します。

    <?xml version="1.0" encoding="UTF-8"?>
<persistence xmlns="http://java.sun.com/xml/ns/persistence"
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd"
             version="2.0">
  <persistence-unit name="com.mystrotv.mdn.admanager.entity">
    <jta-data-source>/dataSource/MystroDS_Tx</jta-data-source>
    <properties>
      <property name="jboss.entity.manager.jndi.name" value="java:/EntityManagers/AdManagerPersistenceContext"/>
      <property name="jboss.entity.manager.factory.jndi.name" value="java:/EntityManagers/AdManagerPersistenceUnit"/>
      <property name="hibernate.dialect" value="org.hibernate.dialect.Oracle10gDialect"/>
      <property name="hibernate.hbm2ddl.auto" value="validate"/>
      <property name="hibernate.max_fetch_depth" value="5"/>
      <property name="hibernate.validator.apply_to_ddl" value="false" />
      <property name="hibernate.validator.autoregister_listeners" value="false" />
    </properties>
  </persistence-unit>
</persistence>

JTAデータソースに基づいて休止状態の方言を定義したいと思います。オラクルの場合は以下の方言を使用し、ポストグレスの場合は別の方言を使用します。誰かがこれを行う方法を知っていますか、またはそれを行う方法に関するドキュメントを私に示すことができますか?Googleは必要な情報を提供できませんでした。アプリはJBossアプリサーバーにデプロイされますが、他のアプリサーバーもサポートしたいと思います。さらに、2つのデプロイメントモデルがあります。1つはpostgresを使用し、もう1つはoracleとIdを使用し、構成ファイルで1行の違いをサポートするために2つのEarを構築する必要はありません。

前もって感謝します。

4

1 に答える 1

4

質問を投稿した直後に、答えが見つかりました。

http://docs.jboss.org/hibernate/core/3.6/reference/en-US/html_single/#portability-dialectresolver

具体的には、方言が指定されていない場合、3.2 以降のバージョンの hibernate は JTA データ ソースからそれを自動検出する必要があるため、正しい手順は方言の指定をプロパティから完全に除外することです。

于 2013-02-19T17:22:39.533 に答える