gpt4 book ai didi

java - Hibernate-search 无法在映射组件中找到字段

转载 作者:行者123 更新时间:2023-12-01 12:31:57 25 4
gpt4 key购买 nike

我有一个包含地址的用户类。我已将地址映射为组件。 User 中的 Address 变量定义为 @IndexEmbedded,Address 类本身定义为 @Embeddable。数据库中的用户表也包含地址字段的列。我可以保存用户并确认它确实保存了地址字段。我可以在用户字段中使用 Hibernate 搜索查询进行搜索,这会提供预期的结果。但是,在地址中搜索字段会出现以下错误:

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)

我正在使用以下版本:

  • hibernate-4.3.5
  • hibernate-search-4.5.1
  • spring-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>

欢迎任何为我指明解决此问题的正确方向的帮助。我发现了对这样的问题的引用 here ,但从我在那里读到的内容来看,我使用的版本应该修复了该错误。

最佳答案

@IndexedEmbedded 可能在编译类型 Address 上求值,该类型没有 place 属性。 AddressImpl 有,但 hibernate 搜索可能不会查看运行时类型。

一般来说,我不会在实体模型类上使用接口(interface)。

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

米哈尔

关于java - Hibernate-search 无法在映射组件中找到字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25864653/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com