簡體   English   中英

Hibernate搜索無法在映射的組件中找到字段

[英]Hibernate-search cannot find field in mapped component

我有一個包含地址的User類。 我已經將地址映射為一個組件。 User中的Address變量定義為@ IndexEmbedded,Address類本身定義為@Embeddable。 數據庫中的用戶表也包含來自“地址”字段的列。 我可以保存用戶並確認它確實保存了地址字段。 我可以在用戶字段中使用“休眠搜索查詢”進行搜索,這樣可以提供預期的結果。 但是,在“地址”中搜索字段會出現以下錯誤:

java.lang.AssertionError: Unable to find field address.place in com.prism.model.user.impl.UserImpl
at org.junit.Assert.fail(Assert.java:88)
at com.prism.dao.hibernate.UserDAOTest.testSearchUser(UserDAOTest.java:104)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:606)
at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:47)
at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:44)
at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
at org.springframework.test.context.junit4.statements.RunBeforeTestMethodCallbacks.evaluate(RunBeforeTestMethodCallbacks.java:74)
at org.springframework.test.context.junit4.statements.RunAfterTestMethodCallbacks.evaluate(RunAfterTestMethodCallbacks.java:83)
at org.springframework.test.context.junit4.statements.SpringRepeat.evaluate(SpringRepeat.java:72)
at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:233)
at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:87)
at org.junit.runners.ParentRunner$3.run(ParentRunner.java:238)
at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:63)
at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:236)
at org.junit.runners.ParentRunner.access$000(ParentRunner.java:53)
at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:229)
at org.springframework.test.context.junit4.statements.RunBeforeTestClassCallbacks.evaluate(RunBeforeTestClassCallbacks.java:61)
at org.springframework.test.context.junit4.statements.RunAfterTestClassCallbacks.evaluate(RunAfterTestClassCallbacks.java:71)
at org.junit.runners.ParentRunner.run(ParentRunner.java:309)
at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.run(SpringJUnit4ClassRunner.java:176)
at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:50)
at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:467)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197)

我正在使用以下版本:

  • 冬眠-4.3.5
  • 休眠 - 搜索4.5.1
  • 彈簧4.0.5

不知道這是否是有用的信息,但是數據庫是MySql 5.6

User類(省略的gettes和setter):

    package com.prism.model.user.impl;

    import java.io.Serializable;
    import java.util.ArrayList;
    import java.util.Collection;
    import java.util.HashSet;
    import java.util.List;
    import java.util.Set;

import javax.persistence.Column;
import javax.persistence.Embedded;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Table;
import javax.persistence.Transient;

import org.hibernate.annotations.Type;
import org.hibernate.search.annotations.DocumentId;
import org.hibernate.search.annotations.Field;
import org.hibernate.search.annotations.Indexed;
import org.hibernate.search.annotations.IndexedEmbedded;
import org.joda.time.DateTime;
import org.springframework.security.core.GrantedAuthority;
import org.springframework.security.core.userdetails.UserDetails;

import com.prism.dao.audit.Auditable;
import com.prism.model.Address;
import com.prism.model.impl.AddressImpl;
import com.prism.model.impl.AuditableObject;
import com.prism.model.user.Role;
import com.prism.model.user.User;

/**
 * @see com.prism.model.user.User
 * 
 * <a href="UserImpl.java.html"><i>View Source</i></a>
 */
@Indexed
@Entity
@Table(name="user")
public class UserImpl extends AuditableObject implements User, UserDetails, Auditable, Serializable {

    /**
     * 
     */
    private static final long serialVersionUID = -34654639867985476L;
    @DocumentId
    @Id @GeneratedValue(strategy=GenerationType.AUTO)
    private long id;
    @Field
    private String username;
    @Field
    private String lastname;
    @Field
    private String middlenames;
    @Field
    private String firstname;
    @Field
    private String fullname;
    @IndexedEmbedded
    @Embedded
    private Address address = new AddressImpl();

    // Account properties
    /**
     * The hashed password
     */
    private String password;
    private int passwordtries;
    @Type(type="org.jadira.usertype.dateandtime.joda.PersistentDateTime")
    @Column(name = "password_last_changed")
    private DateTime passwordLastChanged;
    private boolean enabled;
    @Column(name = "expired")
    private boolean accountExpired;
    @Column(name = "locked")
    private boolean accountLocked;
    @Column(name = "credentials_expired")
    private boolean credentialsExpired;
    private int status;
    @Transient
    private Set<Role> roles = new HashSet<Role>();

    UserImpl() {
        super();
    }

    <omitted gettes and setters>

}

Address類(省略了getter和setter的方法):

/**
 * 
 */
package com.prism.model.impl;

import javax.persistence.Column;
import javax.persistence.Embeddable;
import javax.persistence.Transient;

import org.hibernate.search.annotations.Field;

import com.prism.model.Address;
import com.prism.model.Zipcode;

/**
 * @see com.prism.model.Address
 */
@Embeddable
public class AddressImpl implements Address {

    @Field
    private String building;
    private String country;
    private String housenumber;
    @Column(name = "housenumber_addon")
    private String housenumberAddon;
    @Field
    private String place;
    @Column(name = "post_address")
    private String postAddressLine;
    @Field
    private String zipcode;
    @Column(name = "pre_address")
    private String preAddressLine;
    @Field
    private String room;
    @Field
    private String street;

    <getters and setters>

}

用於測試的spring應用程序上下文文件:

<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:security="http://www.springframework.org/schema/security"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://www.springframework.org/schema/beans
    http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
    http://www.springframework.org/schema/security
    http://www.springframework.org/schema/security/spring-security-3.2.xsd">

    <!-- Hibernate SessionFactory -->
    <bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
        <property name="dataSource" ref="dataSource"/>
        <property name="packagesToScan" value="com.prism" />
        <property name="entityInterceptor" ref="auditInterceptor"/>
        <property name="hibernateProperties">
        <props>
            <prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop>
            <prop key="javax.persistence.validation.mode">none</prop>
            <prop key="hibernate.search.default.directory_provider">filesystem</prop>
            <prop key="hibernate.search.default.indexBase">/data/prism/hibernate/indexes</prop>
            <prop key="jadira.usertype.autoRegisterUserTypes">true</prop>
            <prop key="jadira.usertype.databaseZone">jvm</prop>
            <prop key="jadira.usertype.javaZone">jvm</prop>
        </props>
        </property>
    </bean>

    <bean id="auditInterceptor" class="com.prism.dao.audit.AuditInterceptor">
    </bean>

     <!-- Transaction manager for a single Hibernate SessionFactory (alternative to JTA) -->
    <bean id="transactionManager" class="org.springframework.orm.hibernate4.HibernateTransactionManager">
        <property name="sessionFactory" ref="sessionFactory"/>
    </bean>

    <!-- 
            DAO's 
    -->
    <bean id="dao" class="com.prism.dao.hibernate.BaseDAOHibernate">
        <property name="sessionFactory" ref="sessionFactory"/>
    </bean>

    <bean id="userDAO" class="com.prism.dao.hibernate.UserDAOHibernate">
        <property name="sessionFactory" ref="sessionFactory"/>
    </bean>

</beans>

歡迎為我指出正確的解決方法。 我在這里找到了類似問題的參考,但是從那里我所讀的版本應該修復了該錯誤。

@IndexedEmbedded可能是在沒有位置屬性的編譯類型Address上求值的。 雖然有AddressImpl,但是休眠搜索可能不會查看運行時類型。

通常,我不會在實體模型類上使用接口。

使用luke,您還可以查看索引並查看哪些字段可用。

米哈爾

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM