如何使用JPA和Hibernate通过自定义对象实体属性进行查询

mal*_*ent 2 java orm hibernate jpa hibernate-mapping

编写DAO方法以通过电子邮件检索appUsers,其中email属于EmailAddress类。一直在寻找如何做到这一点无济于事。有没有一种方法可以根据自定义对象的值来检索记录?当我拥有String或int类型的属性时,这似乎起作用,但是如何获取与我的EmailAddress对象匹配的记录?

尝试了以下操作,但不起作用:

public List<AppUser> findByEmail(EmailAddress email) {
    log.debug("finding " + getTable() + " instance by example");

    AppUser appUser = new AppUser();
    appUser.setEmail(email);

    try {
        List<AppUser> results = this.sessionFactory.getCurrentSession()
                .createCriteria(AppUser.class)
                .add(Example.create(appUser)).list();
        log.debug("find by example successful, result size: "
                + results.size());
        return results;
    } catch (RuntimeException re) {
        log.error("find by example failed", re);
        throw re;
    }
}
Run Code Online (Sandbox Code Playgroud)

这是我的AppUser类的相关部分

@Entity
@Table(name="AppUser")
public class AppUser extends BaseEntity {
    ...

    @Column(name="Email")
    private EmailAddress email;

    ...

    /**
     * Gets this AppUser's associated email
     * 
     * @return this AppUser's associated email
     */
    public EmailAddress getEmail() {
        return this.email;
    }

    /**
     * Sets this AppUser's associated email
     * 
     * @param email this AppUser's associated email
     */
    public void setEmail(EmailAddress email) {
        this.email = email;
    }   
}
Run Code Online (Sandbox Code Playgroud)

这是我的EmailAddress类

  public class EmailAddress implements Serializable {
    private static final long serialVersionUID = -6999956021169014445L;
    private static final String AT_DELIMTER = "@";
    private String emailAddress;

    public EmailAddress() {}

    public EmailAddress(String emailAddress) {
        setEmailAddress(emailAddress);
    }

    public String getEmailAddress() {
        return emailAddress;
    }

    public void setEmailAddress(String emailAddress) throws IllegalArgumentException {
        if (StringUtils.isEmpty(emailAddress))
            throw new IllegalArgumentException("Parameter emailAddress cannot be blank.");
        else if (!EmailValidator.getInstance(true).isValid(emailAddress))
            throw new IllegalArgumentException("The email address " +  emailAddress + " is not valid.");

        this.emailAddress = emailAddress;
    }

    public String getUser() {
        return this.emailAddress.substring(0, this.emailAddress.indexOf(AT_DELIMTER));
    }

    public String getDomain() {
        return this.emailAddress.substring(this.emailAddress.indexOf(AT_DELIMTER) + 1);
    }

    public String toString() {
        return emailAddress;
    }

    @Override
    public int hashCode() {
        final int prime = 31;
        int result = 1;
        result = prime * result
                + ((emailAddress == null) ? 0 : emailAddress.hashCode());
        return result;
    }

    @Override
    public boolean equals(Object obj) {
        if (this == obj)
            return true;
        if (obj == null)
            return false;
        if (getClass() != obj.getClass())
            return false;
        EmailAddress other = (EmailAddress) obj;
        if (emailAddress == null) {
            if (other.emailAddress != null)
                return false;
        } else if (!emailAddress.equals(other.emailAddress))
            return false;
        return true;
    }
}
Run Code Online (Sandbox Code Playgroud)

谢谢!

Vla*_*cea 5

将您的查询更改为:

List results = this.sessionFactory.getCurrentSession()
    .createQuery("select au from AppUser au where au.email = :email")
    .setParameter("email", email)
    .list();
Run Code Online (Sandbox Code Playgroud)

您需要实现一个Hibernate自定义UserType ,以便在加载时将数据库字符串转换为EmailAddress。

ImmutableTypefrom hibernate-types项目用作自定义Hibernate的基类,Type因为这样实现起来容易得多。