4

在休眠中有什么方法可以将实体的列注释为字符串小写?我的意思是例如

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

我希望休眠将所有查询中的用户名转换为小写,而不是绑定到特定数据库。

4

2 回答 2

5

例如,您可以在 setter 中创建它:

public void setUsername(String username) {
    this.username = username.toLowerCase();
}

或者使用interseptor:

    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/

于 2012-10-28T12:20:35.613 回答
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;  
}
于 2012-10-28T13:27:07.610 回答