Подтвердить что ты не робот

Как сканировать пакеты для объектов Hibernate вместо использования hbm.xml?

В настоящее время я просматриваю пакеты для DAO и сервисов, используя Spring 3.1 и Hibernate 4 через <context:component-scan>. Есть ли способ сделать то же самое для классов с меткой @Entity вместо использования свойства configLocation и hbm.xml файл?

<hibernate-configuration>
    <session-factory>
        <mapping class="com.example.model.User" />
            <!-- etc. -->
    </session-factory>
</hibernate-configuration>
4b9b3361

Ответ 1

<bean id="sessionFactory"
  class="org.springframework.orm.hibernate4.LocalSessionFactoryBean"
  p:dataSource-ref="dataSource"
  p:configLocation="WEB-INF/classes/hibernate.cfg.xml"
  p:packagesToScan="com.example.model"
/>

Отсканирует все в пакете модели. Я использую свой файл cfg.xml для установки таких параметров, как show_sql и hb2ddl.auto.

Ответ 2

Вы можете сделать это в файле application context.xml для сканирования всех классов аннотаций -

<bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
    <property name="dataSource" ref="dataSource" />
    <property name="lobHandler" ref="lobHandler"/>
<property name="packagesToScan">
    <list>
        <value>com.idc.scd.domain</value>
        <value>com.idc.scd.domain.dropdown</value>
        <value>com.idc.scd.domain.external</value>
        <value>com.idc.scd.domain.pk</value>
    </list>
</property>
    <property name="hibernateProperties">
      <props>
            <prop key="hibernate.dialect">org.hibernate.dialect.Oracle10gDialect</prop>
            <prop key="hibernate.show_sql">${hibernate.show_sql}</prop>
        <prop key="hibernate.format_sql">${hibernate.format_sql}</prop>
        <prop key="hibernate.use_sql_comments">${hibernate.use_sql_comments}</prop>
        <prop key="hbm2ddl.auto">validate</prop>
        <prop key="hibernate.cache.use_query_cache">true</prop>
        <prop key="hibernate.connection.release_mode">after_statement</prop>
        <prop key="hibernate.cache.provider_class">net.sf.ehcache.hibernate.EhCacheProvider</prop>
        <prop key="hibernate.cache.use_second_level_cache">${hibernate.cache.use_second_level_cache}</prop>
        <prop key="hibernate.cache.use_structured_entries">${hibernate.cache.use_structured_entries}</prop>
        <prop key="hibernate.jdbc.fetch_size">${hibernate.jdbc.fetch_size}</prop>
        </props>
    </property>
</bean>

Ответ 3

Вы можете использовать свойство mappingLocations Spring, чтобы указать местоположение, в котором Spring будет искать файлы сопоставления спящего режима.

<property name="mappingLocations" value="classpath:com/example/model/hibernate/*.hbm.xml"/>

Надеюсь, что это поможет.

Ответ 4

Упрощение, вы можете использовать в файле конфигурации следующий код: spring -servlet.xml ':

<bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
        <property name="dataSource" ref="dataSource" />
        <property name="configLocation">
            <value>classpath:hibernate.cfg.xml</value>
        </property>
        <property name="hibernateProperties">
            <props>
                <prop key="hibernate.dialect">${jdbc.dialect}</prop>
                <prop key="hibernate.show_sql">true</prop>
            </props>
        </property>
        <property name="packagesToScan" value="com.your.bean.package" />
    </bean>

Примечание:

  • класс AnnotationSessionFactoryBean требуется в "sessionFactory"
  • свойство "packagesToScan" с пакетом аннотированных классов (или список пакетов - пример Кумара для этого)