栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

如何根据特定顺序对休眠状态进行排序

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

如何根据特定顺序对休眠状态进行排序

使用JPQL(HQL)

select fname from Namewhere upper(fname) like :fnameStart or upper(fname) like :fnameMiddleorder by (case when upper(fname) like :fnameStart then 1 else 2 end), fnamequery.setParameter("fnameStart", "XX%");query.setParameter("fnameMiddle", "% XX%");

有条件

有了

Criteria
很多麻烦。首先,您必须在
order
子句中使用本机SQL 。其次,您必须绑定变量。

public class FirstNameOrder extends Order {    public FirstNameOrder() {        super("", true);    }    @Override    public String toSqlString(Criteria criteria, CriteriaQuery criteriaQuery) throws HibernateException {        return "case when upper(FIRST_NAME) like ? then 1 else 2 end";    }}

大小写表达式的语法和

upper
函数名称应根据您的数据库进行更改(当然,如果不同,则应更改列名称)。

将此添加到中很容易

Criteria
,但是没有API可以绑定参数。

我试图通过将未使用的变量传递给自定义sql限制来欺骗Hibernate,以便将其有效地用于

order by
子句中的变量:

Criteria criteria = session.createCriteria(Name.class, "name")   .add(Restrictions.disjunction()      .add(Restrictions.ilike("name.fname", fname + "%"))      .add(Restrictions.ilike("name.fname", "%" + " " + fname + "%")))   .setProjection(Projections.property("name.fname").as("fname"))   .add(Restrictions.sqlRestriction("1 = 1", fname + "%", StringType.INSTANCE))   .addOrder(new FirstNameOrder())   .addOrder(Order.asc("fname"));

而且效果很好。

显然,不建议使用此解决方案,我建议对此查询使用JPQL。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/509542.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号