我一直在尝试使用带有JPA的Hibernate Search两天,并且我已经完成了所有编译工作 没有任何明显的错误运行。但是,当我尝试创建初始索引时,程序会运行并打印出每个索引 对象它正在索引(使用手动索引),然后打印“索引已完成”消息。不会抛出任何错误, 但主要方法永远不会退出。我正在使用jre1.7在Maven项目中运行Eclipse Kepler,所以我可以通过点击红色停止按钮来终止处理。 如果我这样做,然后搜索索引文件的文件,我找不到。如果我运行我的搜索程序,我会得到 java.lang.IllegalArgumentException:没有指定的实体类型或它们的任何子类被索引。
我会真正了解如何让它发挥作用的任何建议。我试过回到4.2版 hibernate搜索,我得到同样的东西。
Domain类是Car。这是索引器输出:
Indexing: Make Infinity Model G35
Indexing: Make Honda Model Civic
Indexing: Make Audi Model A4
Indexing: Make Toyota Model Carolla
Indexing Completed
如果在调试器中运行,则调试窗口会在程序退出时显示以下活动线程:
com.xyzco.search.Indexer at localhost:52231
Daemon Thread [MySQL Statement Cancellation Timer] (Running)
Thread [Hibernate Search: Index updates queue processor for index com.xyzco.search.Car-1] (Running)
Thread [Hibernate Search: IndexWriter worker executor for com.xyzco.search.Car-1] (Running)
Thread [DestroyJavaVM] (Running)
以下是索引器代码:
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import org.hibernate.search.jpa.FullTextEntityManager;
public class Indexer {
public static void main(String[] args) {
try {
EntityManagerFactory entityManagerFactory = Persistence
.createEntityManagerFactory("dbschema");
EntityManager em = entityManagerFactory.createEntityManager();
FullTextEntityManager ftem = org.hibernate.search.jpa.Search
.getFullTextEntityManager(em);
ftem.getTransaction().begin();
@SuppressWarnings("unchecked")
List<Car> cars = em.createQuery(
"select c from Car c").getResultList();
for (Car car : cars) {
ftem.index(car); // manually index an item instance
System.out.println("Indexing: Make " + car.getMake() + " Model " + car.getModel());
}
ftem.getTransaction().commit(); // index are written at commit time
em.close();
System.out.println("Indexing Completed");
} catch (Exception e) {
e.printStackTrace();
}
}
}
这是Car类代码:
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import org.hibernate.search.annotations.Analyze;
import org.hibernate.search.annotations.DocumentId;
import org.hibernate.search.annotations.Field;
import org.hibernate.search.annotations.Index;
import org.hibernate.search.annotations.Indexed;
import org.hibernate.search.annotations.Store;
@Entity
@Indexed //Mark for indexing
public class Car {
@Id @GeneratedValue
@DocumentId //Mark id property shared by Core and Search
private Integer id;
@Field //Mark for indexing using tokenization
private String make;
@Field
private String model;
@Field(index=Index.YES, analyze=Analyze.NO, store=Store.NO)
private String description;
@Field(index=Index.YES, analyze=Analyze.NO, store=Store.NO)
private String options;
// getters and setters left out...
}
这是persistence.xml
<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_1_0.xsd"
version="1.0">
<persistence-unit name="dbschema"> <!-- transaction-type="RESOURCE_LOCAL"> -->
<provider>org.hibernate.ejb.HibernatePersistence</provider>
<class>com.xyzco.search.Car</class>
<properties>
<property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5InnoDBDialect"/>
<property name="hibernate.hbm2ddl.auto" value="update"/>
<property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver"/>
<property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost:3306/referencedata"/>
<property name="javax.persistence.jdbc.user" value="root"/>
<property name="javax.persistence.jdbc.password" value=""/>
<property name="hibernate.search.default.directory_provider"
value="filesystem" />
<property name="hibernate.search.default.indexBase" value="/usr/lucene/indexes" />
</properties>
</persistence-unit>
</persistence>
以下是POM的一部分(使用Hibernate站点上建议的配置文件)
...
<profile>
<id>jboss-public-repository</id>
...
<dependencies>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>${sl4j.version}</version>
</dependency>
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.14</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.6</version>
</dependency>
<dependency>
<groupId>javax.inject</groupId>
<artifactId>javax.inject</artifactId>
<version>1</version>
</dependency>
<!-- HIBERNATE SEARCH -->
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-entitymanager</artifactId>
<version>4.2.2.Final</version>
</dependency>
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-search</artifactId>
<version>4.3.0.Final</version>
</dependency>
<dependency>
<groupId>org.apache.lucene</groupId>
<artifactId>lucene-core</artifactId>
<version>3.6.2</version>
</dependency>
</dependencies>
答案 0 :(得分:0)
在Indexer类中,关闭实体管理器(em.close)后,必须关闭实体管理器工厂(entityManagerFactory.close();),否则程序将挂起。常见问题列表中对此进行了解释,这是一个常见问题,但令人惊讶的是,有多少示例仅显示代码片段,并且不包含此行。