Hibernate中的小写注释

时间:2012-10-28 11:50:16

标签: java hibernate jpa

在hibernate中是否有任何方法可以将实体的列注释为字符串小写?我的意思是例如

@Entity  
public class User {  
    @Column  
    private String username;  
}

我希望hibernate在未绑定到特定数据库的所有查询中将用户名转换为小写。

2 个答案:

答案 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;  
}