gpt4 book ai didi

jpa - 在嵌入对象上使用 CriteriaBuilder

转载 作者:行者123 更新时间:2023-12-01 12:38:05 26 4
gpt4 key购买 nike

我正在尝试使用 @EmbeddableCriteriaBuilder过滤父结果 Entity基于嵌入的属性。我使用 Eclipse Link 来生成元数据类。
这是嵌入的类/实体:

@Embeddable
public class Stamp implements Serializable {

@Basic()
@Column(name = "stamp_year", nullable = false)
private int year;
父类具有 Stamp作为成员(member):
@Entity(name = "Message")
public class Message implements Serializable {

@Embedded
private Stamp stamp = new Stamp();
现在这段代码应该使用 Message基于嵌入的类属性年份分类和过滤结果:
    CriteriaBuilder cb = em.getCriteriaBuilder();
CriteriaQuery<Message> cq = cb.createQuery(Message.class);
Root<Message> root = cq.from(Message.class);
Predicate p = cb.conjunction();
p = ??????
cq.where(p);
TypedQuery<Message> tq = em.createQuery(cq);
List<Message> messages = tq.getResultList();
在第 5 行,如何到达查询的 Message->Stamp->Year 元素?
这是生成的元模型类:
@StaticMetamodel(Message.class)
public class Message_ {

public static volatile SingularAttribute<Message, Stamp> stamp;
和:
@StaticMetamodel(Stamp.class)
public class Stamp_ {

public static volatile SingularAttribute<Stamp, Integer> year;
注意:为了代码清晰,我删除了所有不相关的信息,但完整的代码可以在 GitHub 上找到:
prototype

最佳答案

基于条件的查询可能如下所示:

CriteriaBuilder cb = em.getCriteriaBuilder();
CriteriaQuery<Message> cq = cb.createQuery(Message.class);
Root<Message> root = cq.from(Message.class);

Predicate p = cb.conjunction();
ParameterExpression<Integer> year = cb.parameter(Integer.class, "year");
p = cb.and(p, cb.equal(root.get(Message_.stamp).get(Stamp_.year), year));

cq.where(p);

TypedQuery<Message> tq = em.createQuery(cq).setParameter("year", 2015);
List<Message> messages = tq.getResultList();

关于jpa - 在嵌入对象上使用 CriteriaBuilder,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27739559/

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