gpt4 book ai didi

java - 具有最大值的实体的 HQL 查询

转载 作者:IT老高 更新时间:2023-10-28 21:04:36 25 4
gpt4 key购买 nike

我有一个看起来像这样的 Hibernate 实体(为简洁起见,省略了访问器):

@Entity
@Table(name="FeatureList_Version")
@SecondaryTable(name="FeatureList",
pkJoinColumns=@PrimaryKeyJoinColumn(name="FeatureList_Key"))
public class FeatureList implements Serializable {

@Id
@Column(name="FeatureList_Version_Key")
private String key;

@Column(name="Name",table="FeatureList")
private String name;

@Column(name="VERSION")
private Integer version;

}

我想制作一个 HQL 查询来检索 FeatureList 的最新版本。以下查询类型有效:

Select f.name, max(f.version) from FeatureList f group by f.name

问题是它不会填充关键字段,我需要包含给定 FeatureList 的最高版本号记录的关键。如果我在选择中添加 f.key 它将不起作用,因为它不在 group by 或聚合中,如果我将它放在 group by 整个事情停止工作,它只是给我每个版本作为一个单独的实体。

那么,有人可以帮忙吗?

最佳答案

这个查询的简单版本如下所示(假设 (name, version) 对是唯一的):

select f from FeatureList f 
where f.version =
(select max(ff.version) from FeatureList ff where ff.name = f.name)

关于java - 具有最大值的实体的 HQL 查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4497624/

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