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)
谢谢!
将您的查询更改为:
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。
将ImmutableType
from hibernate-types
项目用作自定义Hibernate的基类,Type
因为这样实现起来容易得多。
归档时间: |
|
查看次数: |
4681 次 |
最近记录: |