在hibernate中是否有任何方法可以将实体的列注释为字符串小写?我的意思是例如
@Entity
public class User {
@Column
private String username;
}
我希望hibernate在未绑定到特定数据库的所有查询中将用户名转换为小写。
答案 0 :(得分:5)
例如,您可以在setter中创建它:
public void setUsername(String username) {
this.username = username.toLowerCase();
}
或使用拦截器:
public boolean onSave(Object entity,Serializable id, Object[] state,String[] propertyNames,Type[] types) throws CallbackException {
if (entity instanceof User ){
entity.username = usename.toLowerCase();
}
return false;
}
你可以在这里阅读更多关于拦截器的信息: http://www.mkyong.com/hibernate/hibernate-interceptor-example-audit-log/
答案 1 :(得分:4)
您可以为此字符串编写自己的UserType
public class LowerCaseString implements UserType
{
//....
public void nullSafeSet(PreparedStatement preparedStatement, Object value, int index)
throws HibernateException, SQLException {
Hibernate.STRING.nullSafeSet(preparedStatement,
(value != null) ? ((String)value).toLowerCase() : null, index);
}
///....
}
你的实体
@Entity
public class User {
@Column
@Type(type="com.youcompany.LowerCaseString")
private String username;
}