Hibernate-поиск с помощью Hibernate - PullRequest
0 голосов
/ 02 ноября 2010

Можно ли использовать поиск hibernate с hibernate, но без jpa. Я использую только аннотацию jpa, но не использую entityManager.

В этом случае, как поиск hibernate может узнать, что он должен индексировать объект, когда я создаю новый объект в БД, используя сеанс hibernate.

Пока у меня просто есть сущность, которая называется "человек". Я добавил @indexed к этой сущности, и теперь я больше не могу обновлять сущность человека в базе данных. Возникает исключение при вызове session.flush во время транзакции, которая обновляет эту сущность.

спасибо.


Вот что я сделал до сих пор,

Я добавил в hibernate.cfg.xml:

  <property name="hibernate.search.default.directory_provider">
  org.hibernate.search.store.FSDirectoryProvider
  </property>
  <property name="hibernate.search.default.indexBase">./lucene/indexes</property>
  <property name="hibernate.search.default.batch.merge_factor">10</property>
  <property name="hibernate.search.default.batch.max_buffered_docs">10</property>

    <event type="post-update">
        <listener class="org.hibernate.search.event.FullTextIndexEventListener"/>
    </event>
    <event type="post-insert">
        <listener class="org.hibernate.search.event.FullTextIndexEventListener"/>
    </event>
    <event type="post-delete">
        <listener class="org.hibernate.search.event.FullTextIndexEventListener"/>
    </event>

давайте предположим следующую сущность "версия":

@Entity
@Indexed(index="indexes/versions")
@Table(name="VERSIONS")
public class Version implements Serializable {

  @Id
  @DocumentId
  @GeneratedValue(strategy=GenerationType.AUTO)
  @Column(name="V_NO", length=10)
  private Integer valueNb;

  @Column(nullable=false)
  @Temporal(TemporalType.TIMESTAMP)
  private Date tstamp;

Это метод, который сохраняет версию:

  private Version performUpdateActualOnCreation(Session session, VersionedObject storedObject, String userId, String message) {
    // create new version
    Version version = new Version(userId, message);
    session.save(version);

    // update previous version do the object with the Next Value NB
    if (storedObject != null) {
      storedObject.setNextVersion(version);
      session.update(storedObject);
    } else {
      logger.error("Error: trying to update versioned object which has no previous version!!");
    }

    session.flush();

    return version;
  }

Проблема связана с session.flush (); Вот трассировка стека, но я ничего внутри не вижу. (Я также вижу, что индексный файл создан 'indexes / version', но он пуст)

DEBUG 2010-11-02 17:26:33,368+0100 http-8889-Processor6 com.data.server.dao.impl.HibernateDao.rollbackTransaction(HibernateDao.java:104) Rolling back Hibernate transaction 
com.google.gwt.user.client.rpc.StatusCodeException: The call failed on the server; see server log for details
    at com.google.gwt.user.client.rpc.impl.RequestCallbackAdapter.onResponseReceived(RequestCallbackAdapter.java:192)
    at com.google.gwt.http.client.Request.fireOnResponseReceived(Request.java:287)
    at com.google.gwt.http.client.RequestBuilder$1.onReadyStateChange(RequestBuilder.java:393)
    at sun.reflect.GeneratedMethodAccessor50.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at com.google.gwt.dev.shell.MethodAdaptor.invoke(MethodAdaptor.java:103)
    at com.google.gwt.dev.shell.MethodDispatch.invoke(MethodDispatch.java:71)
    at com.google.gwt.dev.shell.OophmSessionHandler.invoke(OophmSessionHandler.java:157)
    at com.google.gwt.dev.shell.BrowserChannel.reactToMessagesWhileWaitingForReturn(BrowserChannel.java:1713)
    at com.google.gwt.dev.shell.BrowserChannelServer.invokeJavascript(BrowserChannelServer.java:165)
    at com.google.gwt.dev.shell.ModuleSpaceOOPHM.doInvoke(ModuleSpaceOOPHM.java:120)
    at com.google.gwt.dev.shell.ModuleSpace.invokeNative(ModuleSpace.java:507)
    at com.google.gwt.dev.shell.ModuleSpace.invokeNativeObject(ModuleSpace.java:264)
    at com.google.gwt.dev.shell.JavaScriptHost.invokeNativeObject(JavaScriptHost.java:91)
    at com.google.gwt.core.client.impl.Impl.apply(Impl.java)
    at com.google.gwt.core.client.impl.Impl.entry0(Impl.java:188)
    at sun.reflect.GeneratedMethodAccessor44.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at com.google.gwt.dev.shell.MethodAdaptor.invoke(MethodAdaptor.java:103)
    at com.google.gwt.dev.shell.MethodDispatch.invoke(MethodDispatch.java:71)
    at com.google.gwt.dev.shell.OophmSessionHandler.invoke(OophmSessionHandler.java:157)
    at com.google.gwt.dev.shell.BrowserChannel.reactToMessages(BrowserChannel.java:1668)
    at com.google.gwt.dev.shell.BrowserChannelServer.processConnection(BrowserChannelServer.java:401)
    at com.google.gwt.dev.shell.BrowserChannelServer.run(BrowserChannelServer.java:222)
    at java.lang.Thread.run(Thread.java:619)

Ответы [ 2 ]

1 голос
/ 02 ноября 2010

Согласно документации Hibernate Search :

Если вы используете Hibernate напрямую, это можно сделать в hibernate.properties или hibernate.cfg.xml.Если вы используете Hibernate через JPA, вы также можете добавить свойства в файл persistence.xml.

Вы можете использовать Поиск Hibernate в любом случае.Нужно ли использовать аннотации JPA или вы можете переключиться на аннотации Hibernate?Чтобы получить дополнительную помощь по вашему исключению, вы должны опубликовать трассировку стека.

0 голосов
/ 03 ноября 2010

У меня есть больше информации ... (+ теперь я использую аннотации в спящем режиме)

В журнале я вижу:

[INFO] class org.hibernate.cfg.ExtendedMappings has interface org.hibernate 
.cfg.Mappings as super class 

Я думаю, что это несовместимо с версией hibernate-search. Вот зависимости, использующие Ivy

<dependency org="org.hibernate" name="hibernate-core" rev="3.3.2.GA" conf="runtime->default,optional;full->sources"/>
<dependency org="org.hibernate" name="hibernate-annotations" rev="3.4.0.GA" conf="runtime->default;full->sources"/>

<dependency org="org.hibernate" name="hibernate-search" rev="3.2.0.Final" conf="runtime->default,optional;full->sources">
   <exclude org="javax.jms" name="jms" />
</dependency>

Я посмотрел на Матрицу совместимости hibernate, я увидел для Hibernate-core.3.3.2, что Hibernate 3.1.x совместим. Я возьму предыдущую версию и посмотрю, что произойдет

...