您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

在Hibernate Criteria中将日期转换为字符串

在Hibernate Criteria中将日期转换为字符串

我遇到了同样的问题,这是我做的:

首先,我创建了自己的Criterion实现:

public class DateLikeExpression implements Criterion {

private static final long serialVersionUID = 1L;
private String propertyName;
private String value;

public DateLikeExpression(String propertyName, String value) {
    this.propertyName = propertyName;
    this.value = value;
}

public String tosqlString(Criteria criteria, CriteriaQuery criteriaQuery) throws HibernateException {
    String[] columns = criteriaQuery.getColumnsUsingProjection(criteria, propertyName);
    if (columns.length != 1) {
        throw new HibernateException("Like may only be used with single-column properties");
    }
    return "to_char(" + columns[0] + ", 'DD/MM/YYYY HH24:MI') like ?";
}

public TypedValue[] getTypedValues(Criteria criteria, CriteriaQuery criteriaQuery) throws HibernateException {
    return new TypedValue[] { new TypedValue(new org.hibernate.type.StringType(),
            MatchMode.START.toMatchString(value.toLowerCase()), EntityMode.POJO) };
}

}

然后,当我将条件放在一起时,我就用它:

criteria.add(new DateLikeExpression("dateColumnName", "26/11%"));

就是这样。请注意,此实现 语言环境相关的(在这种情况下为pt_BR),并且适用于具有to_char函数的postgresql。您可能需要稍微调整一下才能使用数据库引擎。

其他 2022/1/1 18:20:29 有529人围观

撰写回答


你尚未登录,登录后可以

和开发者交流问题的细节

关注并接收问题和回答的更新提醒

参与内容的编辑和改进,让解决方法与时俱进

请先登录

推荐问题


联系我
置顶