Spring 3.1.1 + Hibernate 4.1.0 - не индексируется? - PullRequest
2 голосов
/ 25 марта 2012

Индексирование новых элементов, не работающих с Hibernate + Spring. В журналах не отображаются ошибки.

Версии Hibernate и Spring:

  • Hibernate 4.1.0.Final
  • Hibernate Search 4.0.0.Final
  • Hibernate EntityManager 4.0.1.Final
  • Spring 3.1.1.RELEASE

Весна-context.xml

<bean id="dataSource" class="org.springframework.jdbc.datasource.LazyConnectionDataSourceProxy">
    <property name="targetDataSource">
        <ref local="mainDataSource" />
    </property>
</bean>

<bean id="mainDataSource" class="com.jolbox.bonecp.BoneCPDataSource" destroy-method="close">
    <property name="driverClass" value="${jdbc.driver}" />
    <property name="jdbcUrl" value="${jdbc.url}" />
    <property name="username" value="${jdbc.username}"/>
    <property name="password" value="${jdbc.password}"/>

    <property name="idleConnectionTestPeriodInMinutes" value="${jdbc.idleConnectionTestPeriodInMinutes}"/>
    <property name="idleMaxAgeInMinutes" value="${jdbc.idleMaxAgeInMinutes}"/>      
    <property name="maxConnectionsPerPartition" value="${jdbc.maxConnectionsPerPartition}"/>
    <property name="minConnectionsPerPartition" value="${jdbc.minConnectionsPerPartition}"/>
    <property name="partitionCount" value="${jdbc.partitionCount}"/>
    <property name="acquireIncrement" value="${jdbc.acquireIncrement}"/>                              
    <property name="statementsCacheSize" value="${jdbc.statementsCacheSize}"/>
    <property name="releaseHelperThreads" value="${jdbc.releaseHelperThreads}"/>
</bean>

<bean id="sessionFactory"
    class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
    <property name="dataSource" ref="dataSource" />
    <property name="hibernateProperties">
        <props>
            <prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop>
            <prop key="hibernate.show_sql">${hibernate.show_sql}</prop>
            <prop key="hibernate.hbm2ddl.auto">none</prop>

            <prop key="hibernate.connection.release_mode">auto</prop>
            <prop key="hibernate.auto_close_session">true</prop>


            <prop key="hibernate.cache.use_query_cache">true</prop>
            <prop key="hibernate.cache.use_second_level_cache">true</prop>
            <prop key="hibernate.cache.use_query_cache">true</prop>
            <prop key="hibernate.cache.region.factory_class">org.hibernate.cache.ehcache.SingletonEhCacheRegionFactory</prop>

            <!-- Hibernate search - lucene -->
            <prop key="hibernate.search.default.directory_provider">filesystem</prop>
            <prop key="hibernate.search.default.indexBase">/temp/lucene</prop>
        </props>
    </property>
    <property name="packagesToScan" value="com.example.domain" />
</bean>

<bean id="transactionManager"
    class="org.springframework.orm.hibernate4.HibernateTransactionManager">
    <property name="sessionFactory" ref="sessionFactory" />
</bean>

<tx:annotation-driven transaction-manager="transactionManager" />

Фрагмент кода индексируемого класса

@Indexed
@Entity
@Table(name = "table_name")
public class VideoInfo implements Serializable {
    @Id
    @Column(name = "id")
    @GeneratedValue(strategy = GenerationType.AUTO)
    private long id;

    @Column(name = "title")
    @Field(index=Index.YES, store=Store.NO)
    private String title;

    @Column(name = "tags")
    @Field(index=Index.YES, store=Store.NO)
    private String tags;

    @Column(name = "url")
    private String url;
....

Метод сохранения DAO (фабрика === сессия фабрики)

factory.getCurrentSession().save(obj);

В чем может быть проблема? Сейчас я немного озадачен тем, что мне следует делать, поэтому, пожалуйста, помогите мне:

РЕДАКТИРОВАТЬ: Наконец, перестройка индекса начала работать правильно

1 Ответ

2 голосов
/ 06 апреля 2012

У меня та же проблема, но с Hibernate 4.1, Envers и EJB 3. Я решил ее с помощью аннотации @TransactionAttribute для управления транзакцией. Слушатель Envers не запускается, если транзакция не имеет «нормального завершения». Я надеюсь, что это поможет (извините за мой английский)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...