Сконфигурируйте диалект hibernate, используя JNDI (с Spring) - PullRequest
8 голосов
/ 18 января 2011

Я пытаюсь настроить веб-приложение Spring + Hibernate, используя JNDI вместо файлов свойств.Все работает нормально по адресу базы данных, паролю, имени входа и т. Д., Но я не могу получить диалект из контекста JNDI.

Я использую это в моей базе данных-context.xml:

<bean id="databaseUrl" class="org.springframework.jndi.JndiObjectFactoryBean">
    <property name="jndiName" value="java:comp/env/jdbc/url"/>
</bean>
<bean id="databaseDriver" class="org.springframework.jndi.JndiObjectFactoryBean">
    <property name="jndiName" value="java:comp/env/jdbc/driver"/>
</bean>
<bean id="databaseUsername" class="org.springframework.jndi.JndiObjectFactoryBean">
    <property name="jndiName" value="java:comp/env/jdbc/username"/>
</bean>
<bean id="databasePassword" class="org.springframework.jndi.JndiObjectFactoryBean">
    <property name="jndiName" value="java:comp/env/jdbc/password"/>
</bean>
<bean id="databaseDialect" class="org.springframework.jndi.JndiObjectFactoryBean">
    <property name="jndiName" value="java:comp/env/jdbc/dialect"/>
</bean>

<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
    <property name="driverClassName" ref="databaseDriver"/>
    <property name="url" ref="databaseUrl"/>
    <property name="username" ref=databaseUsername"/>
    <property name="password" ref="databasePassword"/>
    <property name="maxWait" value="30000"/>
    <property name="validationQuery" value="select 1"/>
    <property name="maxActive" value="100"/>
</bean>

<bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
    <property name="dataSource" ref="dataSource"/>
    <property name="packagesToScan">...</property>
    <property name="hibernateProperties">
        <props>
            <prop key="hibernate.hbm2ddl.auto">update</prop>
            <prop key="hibernate.show_sql">true</prop>
            <!--<prop key="hibernate.dialect">org.hibernate.dialect.DerbyDialect</prop>-->
            <!--<prop key="hibernate.dialect">org.hibernate.dialect.MySQL5InnoDBDialect</prop>-->
        </props>
    </property>
</bean>

Проблема в том, что я не знаю, как использовать значение JNDI для databaseDialect внутри свойства <prop name="hibernate.dialect">blabla</prop>.

Есть идеи?

1 Ответ

4 голосов
/ 18 января 2011

Spring может преобразовать Map в Properties объект, поэтому вы можете сделать следующее:

<bean id="sessionFactory"
    class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
    <property name="dataSource" ref="dataSource" />
    <property name="hibernateProperties">
        <util:map>
            <entry key="hibernate.hbm2ddl.auto" value="update" />
            <entry key="hibernate.show_sql" value="true" />
            <entry key="hibernate.dialect">
                <jee:jndi-lookup jndi-name="java:comp/env/jdbc/dialect" />
            </entry>
        </util:map>
    </property>
</bean>

Справка:

Обрабатывает преобразование из контента String до Properties объекта. Также обрабатывает Map в Properties преобразование, для заполнение объекта Properties через XML записи "map".

Источник: PropertiesEditor Javadoc

...