Hibernate动态顺序

发布于 2025-01-05 05:18:50 字数 147 浏览 0 评论 0原文

您好,我想在 HQL 中排序,

ORDER BY IF g.groupAdminId=:adminid THEN 1 ELSE 0 END ASC

但它不起作用,我想首先拥有用户为管理员的所有实体,我该如何归档?

Hi i want to sort in HQL

ORDER BY IF g.groupAdminId=:adminid THEN 1 ELSE 0 END ASC

But it doesn't work, i want to have all entities where the user is admin first, how can i archieve this?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

时光瘦了 2025-01-12 05:18:50

我不认为可以将命名参数放在 where 子句之外。

可以根据表达式进行排序:

from User U
order by case
  when U.group.name = 'Admin' then 0
  when U.group.name = 'Superuser' then 1
  else 2
end asc

有关 HQL 中的 case 的更多信息 docs

对于您的特定问题(管理员在其他用户之前),我建议进行两个查询并在 Java 中组合两个列表。

还有其他方法可以解决此问题,但我不喜欢其中任何一个:

I don't believe it is possible to put named parameters outside a where clause.

It is possible to order according to expressions:

from User U
order by case
  when U.group.name = 'Admin' then 0
  when U.group.name = 'Superuser' then 1
  else 2
end asc

More on case in HQL docs :

For your particular problem (having admins before other users) I suggest making two queries and combining the two lists in Java.

There are other ways around this but I do not like any of them:

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文