Hibernate Search配置及简单应用

 

  Hibernate Search是一款集成Apache Lucene的搜索jar包。

 

  一。配置

 

<dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-core</artifactId>
            <version>${hibernate.version}</version>
        </dependency>
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-entitymanager</artifactId>
            <version>${hibernate.version}</version>
        </dependency>

        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-search</artifactId>
            <version>${hibernate.version}</version>
        </dependency>
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-search-analyzers</artifactId>
            <version>${hibernate.version}</version>
        </dependency>

 

  其中的hibernate.version为4.0.0.CR1。如果hibernate-core的版本过低会导致hibernate-search无法应用,所以在使用之前请谨慎考虑。

 

  在hibernate.cfg.xml中添加如下设置

 

 

<property name="hibernate.search.default.directory_provider">filesystem</property>

        <property name="hibernate.search.default.indexBase">/lucene/indexes</property>

 

  第一个属性表示将使用文件系统作为为默认的目录提供者,第二个属性表示存储目录。

 

  如果想对某个实体进行索引,那么需要在该实体上加上@Indexed注释,对于该实体的标识符上加上@DocumentId注释,并且在你想要进行索引的属性上加上@Field(index = Index.YES, analyze = Analyze.YES, store = Store.YES)注释,其中注释中的设置根据具体需求而定,以后会讲解到这些属性的意义和作用。

 

  二。创建索引

 

  这里以Person为例,对其中的name属性创建索引,创建索引的代码如下:

 

 

SessionFactory sessionFactory = new Configuration().configure().buildSessionFactory();
        Session session = sessionFactory.openSession();
        FullTextSession fullTextSession = Search.getFullTextSession(session);
        fullTextSession.createIndexer(Person.class).startAndWait();

 

  三。搜索

 

 

SessionFactory sessionFactory = new Configuration().configure().buildSessionFactory();
        Session session = sessionFactory.openSession();
        FullTextSession fullTextSession = Search.getFullTextSession(session);
        Transaction transaction = fullTextSession.beginTransaction();
        SearchFactory searchFactory = fullTextSession.getSearchFactory();
        QueryBuilder queryBuilder = searchFactory.buildQueryBuilder().forEntity(Person.class).get();
        Query query = queryBuilder.keyword().onField("name").matching("Zhong").createQuery();
        FullTextQuery fullTextQuery = fullTextSession.createFullTextQuery(query, Person.class);
        List<Person> list = fullTextQuery.list();
        transaction.commit();
        session.close();

 

  先将该项目上传以供参考。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Hibernate是一个Java持久化框架,用于将Java对象映射到关系数据库中。下面是使用JSP、DAO、Service、Implement执行Hibernate的增删改的步骤: 1.创建一个Java类来表示数据库表。例如,如果您有一个名为“users”的表,则可以创建一个名为“User”的Java类,该类具有与表中每个列相对应的属性。 2.创建一个Hibernate配置文件,指定Hibernate将如何与数据库进行交互。配置文件包括数据库连接详细信息、对象映射详细信息等。 3.创建一个DAO接口,该接口定义了可以执行的CRUD操作。例如,如果您要执行SELECT操作,则可以创建一个名为“UserDAO”的接口,并在其中定义一个名为“getUser”的方法。 4.实现DAO接口。创建一个名为“UserDAOImpl”的类,并实现DAO接口中定义的所有方法。在此类中,您将使用Hibernate API与数据库进行交互。 5.创建一个Service接口,该接口将调用DAO接口中定义的方法。例如,如果您要搜索用户,则可以创建一个名为“UserService”的接口,并在其中定义一个名为“searchUser”的方法。 6.实现Service接口。创建一个名为“UserServiceImpl”的类,并实现Service接口中定义的所有方法。在此类中,您将调用DAO接口中定义的方法。 7.创建一个JSP页面,用于显示结果。例如,如果您要搜索用户,则可以创建一个名为“search.jsp”的页面,并在其中使用JSTL等技术显示结果。 8.创建一个Servlet,该Servlet将接收来自JSP页面的请求,并调用Service接口中定义的方法。 9.在web.xml文件中配置Servlet和JSP页面。 10.编译并部署应用程序。 以上是使用JSP、DAO、Service、Implement执行Hibernate的增删改的步骤。注意,这只是一个基本框架,实际上需要根据项目需求进行修改和改进。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值