gpt4 book ai didi

hibernate - 基于独立条件的 createAlias (GORM)

转载 作者:行者123 更新时间:2023-12-02 13:52:26 25 4
gpt4 key购买 nike

对于 Grails 项目,我需要它按关联实体的字段进行排序。就像获取按作者姓名排序的条目:

def crteria = new DetachedCriteria(Entry)
criteria.list {
order('author.name', 'asc')
}

当前示例将失败并显示:

org.hibernate.QueryException: could not resolve property: author.name of: Entry

这是 Hibernate 的常见问题,通常通过引入 author 的别名来完成,例如:

criteria.createAlias('author')
criteria.addOrder(Order.asc('author.name'))

但问题是Grails gorm.DetachedCriteria没有这样的方法,抛出NoSuchMethodException。我不想使用普通的 hibernate.DetachedCritera 来代替,因为需要支持使用 Groovy 标准编写的遗留代码。

如何添加这样的别名?或者如何应用这种排序而不使用它?

也许有一个方法是创建一个 hibernate.DetachedCriteria,添加别名,然后将其转换为 gorm.DetachedCriteria

-

PS 这太疯狂了,groovy order('author.name', 'asc') 对于集成测试来说效果很好。仅在真实应用程序 grails run-app 上失败。

最佳答案

我相信您可以随时从 GORM 标准生成器获取 DetachedCriteria 并使用 HibernateCriteriaBuilder.getHibernateDetachedCriteria(query) 修改它。

GORM DetachedCriteria 只是底层 Hibernate DetachedCriteria 的构建器接口(interface)。

关于hibernate - 基于独立条件的 createAlias (GORM),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21935280/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com