使用 Grails 3 进行 Hibernate 5 搜索

Hibernate 5 Search with Grails 3

我正在使用 Grails 3.1.4,我想使用 Hibernate-Search 对我的实体进行全文搜索。

在我的 build.gradle 中,我包含了 Hibernate 5 和 Hibernate Search

compile "org.hibernate:hibernate-core:5.0.9.Final"
compile "org.hibernate:hibernate-ehcache:5.0.9.Final"
compile "org.hibernate:hibernate-search-orm"

如果我将 @Indexed 添加到我的域之一 类,我会收到以下错误:

ERROR org.springframework.boot.SpringApplication - Application startup failed
org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'transactionManagerPostProcessor': Initialization of bean failed; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'transactionManager': Cannot resolve reference to bean 'sessionFactory' while setting bean property 'sessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sessionFactory': Invocation of init method failed; nested exception is java.lang.NullPointerException
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:553)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:482)
    at org.springframework.beans.factory.support.AbstractBeanFactory.getObject(AbstractBeanFactory.java:306)
    at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:230)
    at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:302)
    at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:202)
    at org.springframework.context.support.PostProcessorRegistrationDelegate.registerBeanPostProcessors(PostProcessorRegistrationDelegate.java:207)
    at org.springframework.context.support.AbstractApplicationContext.registerBeanPostProcessors(AbstractApplicationContext.java:687)
    at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:523)
    at org.springframework.boot.context.embedded.EmbeddedWebApplicationContext.refresh(EmbeddedWebApplicationContext.java:118)
    at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:766)
    at org.springframework.boot.SpringApplication.createAndRefreshContext(SpringApplication.java:361)
    at org.springframework.boot.SpringApplication.run(SpringApplication.java:307)
    at grails.boot.GrailsApp.run(GrailsApp.groovy:55)
    at grails.boot.GrailsApp.run(GrailsApp.groovy:365)
    at grails.boot.GrailsApp.run(GrailsApp.groovy:354)
    at grails.boot.GrailsApp$run.call(Unknown Source)
    at org.codehaus.groovy.runtime.callsite.CallSiteArray.defaultCall(CallSiteArray.java:48)
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:113)
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:133)
    at com.myapp.Application.main(Application.groovy:8)

有没有办法让 Hibernate Search 与 Grails 域一起工作类?

Grails 3.1.4 已经包含 GORM 5 Suite,这意味着您的“build.gradle”文件中的以下行可能是多余的:

compile "org.hibernate:hibernate-core:5.0.9.Final" 
compile "org.hibernate:hibernate-ehcache:5.0.9.Final"
compile "org.hibernate:hibernate-search-orm"

据我所知,通过使用 Grails Hibernate search Plugin.

,hibernate 搜索应该与 Grails 配合得很好

但是,如果您已经在使用 Grails 3.1.4,最简单的方法可能是使用 GORM suite(Grails 对象关系映射)。 GORM 可以简单地访问数据库,使您的代码清晰易读。

巧合的是,我目前正在移植旧的Grails 2 Hibernate Search插件以兼容Grails 3.1.x和Hibernate 5。原作者准备在我创建后立即合并我的PR它。 我刚开发完,有兴趣的可以试试:

https://github.com/lgrignon/grails-hibernate-search-plugin

编辑:

PR 已合并,我刚刚发布在 bintray 上,这是用于插件分发的新 Grails 3 平台。为 Grails 3.1.x / GORM 5 试用新版 Grails Hibernate Search 2.0: 添加以下存储库 maven { url "http://idcapture.bintray.com/plugins" }

并将以下内容添加到您的依赖项中 compile("org.grails.plugins:hibernate-search:2.0")

它应该有效:)

希望对您有所帮助!

如果您正在使用 "org.hibernate:hibernate-core:5.0.9.Final",那么您需要获取 Hibernate Search 的兼容版本:"org.hibernate:hibernate-search-orm:5.5.4.Final"。