- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
总结一下,我有 3 个实体,主要的一个是名为“Rac”的实体。它包含一个“RacNatureza”列表,其中包含一个属性“Natureza”。
拉克
@Entity
@Table(name = "rac")
public class Rac {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long idRac;
@OneToMany(mappedBy = "rac", cascade = {CascadeType.ALL}, orphanRemoval = true)
@JsonManagedReference //para evitar recursão infinita do JSON
private List<RacNatureza> racNaturezas;
//...getters and setters ok
}
@Entity
@Table(name = "rac_natureza")
public class RacNatureza implements Serializable {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "id_rac_natureza")
private Long idRacNatureza;
@ManyToOne
@JsonBackReference //coloquei para evitar a recursao infinita de JSON
@JoinColumn(name="id_rac")
private Rac rac;
@ManyToOne
@JoinColumn(name="id_natureza")
private Natureza natureza;
@Column(name = "principal")
private Boolean principal;
}
@Entity
@Table(name = "natureza")
public class Natureza {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "id_natureza")
private Integer idNatureza;
private String descricao;
@OneToMany(mappedBy = "natureza", fetch = FetchType.EAGER, orphanRemoval = true)
@JsonIgnore
private List<RacNatureza> racNatureza;
}
@PersistenceContext
private EntityManager entityManager;
@Override
public List<Rac> filtrar(RacFilter racFilter) {
CriteriaBuilder builder = entityManager.getCriteriaBuilder();
CriteriaQuery<Rac> criteria = builder.createQuery(Rac.class);
Root<Rac> root = criteria.from(Rac.class);
Predicate[] predicates = criarRestricoes(racFilter, builder, root);
criteria.where(predicates);
TypedQuery<Rac> query = entityManager.createQuery(criteria);
return query.getResultList();
}
@Override
public Predicate[] criarRestricoes(RacFilter racFilter, CriteriaBuilder builder, Root<Rac> root) {
List<Predicate> predicates = new ArrayList<>();
if (racFilter.getNaturezas() != null) {
predicates.add(
builder.equal(root.<List<RacNatureza>>get("racNaturezas").<Natureza>get("natureza"), racFilter.getNaturezas()) );
}
return predicates.toArray(new Predicate[predicates.size()]);
}
predicates.add(
builder.equal(root.<List<RacNatureza>>get("racNaturezas").<Natureza>get("natureza"), racFilter.getNaturezas()) );
}
最佳答案
替换 root.get("racNaturezas")
使用 root.join("racNaturezas")
请不要问我为什么我们不能使用get
关于java - 使用 CriteriaBuilder 在 Java 中获取列表的 IllegalStateException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53820207/
我正在尝试更改以下 HQL 以使用 JPA 标准: select distinct d from Department d left join fetch d.children c where d.p
我对 CriteriaBuilder API 有疑问: 我想计算一列的结果,并返回该计数的结果以及该列的不同值的列表。 | Table_fruit | count(Tab
有什么区别: 在 Builder 上的第一次测试运行: Predicate predicate = root.get(PersonEntity_.name).in(names); criteriaBu
我正在开发一个经常使用 CriteriaBuilder.Coalesce 的大型代码库。和 Root 。例如, criteriaBuilder.coalesce(root.get('adjustedW
我有这样的代码 @OneToOne(fetch = FetchType.LAZY, cascade = CascadeType.ALL, orphanRemoval = true) public Re
我必须重写一些代码,但在互联网上找不到正确的信息。原始部分如下所示: String query = "select * from sublog_type_map_v where 1 = 1"; if
这是我从 CriteriaBuilder 获得的 hibernate 查询: select generatedAlias0 from MyObject as generatedAlias0 where
SELECT * FROM Emp_Main WHERE status = 'QUIT' AND to_Char(effective_date,'YYYY')= '2018'; 在此示例中,我已将代码
我正在尝试使用 @Embeddable与 CriteriaBuilder过滤父结果 Entity基于嵌入的属性。我使用 Eclipse Link 来生成元数据类。 这是嵌入的类/实体: @Embedd
谁能提供一个如何使用 CriteriaBuilder 编写案例查询的示例? 最佳答案 以下是使用 CriteriaBuilder 的示例 case 表达式(这适用于 JPA 2): Hashtable
我想写这个SQL查询 SELECT * FROM A LEFT OUTER JOIN B ON A.IDRESOURCE=B.IDRESOURCE AND B.IDLANGUAGE=22; 使用 J
我想将日期与数据库中的时间戳进行比较。我目前使用的是 predicates.add(criteriaBuilder.between(eventRoot.get("time"), dBegin, dEn
使用 Criteriabuilder 编写查询时,如何在两列上添加相等条件?例如: CriteriaBuilder cb = entityManager.getCriteriaBuilder(); C
我有一个实体 @Entity @Table(name = "`petition`") @Getter @Setter public class Petition extends Auditable {
嗯,我正在使用 CriteriaBuilder 和 PredicateList 来处理 JPA 并从数据库中提取信息,事实是它包含带重音的数据,我需要进行搜索,即使我搜索不带重音的单词,我也会找到带重
我有一个要附加到 or 条件中的列表 我面临的问题是当我遍历 List 并将其添加到 CategoryBuilder 然后它采用最后一个 Predicate 例子如下: public static S
我正在尝试计算给定的纬度/经度和距离,并且只返回落在该圆距离内的行(数据库也有纬度/经度坐标)。我不知道的是我会怎么做。我目前正在使用 native SQL 并使用纯文本和计算它的半正弦公式,如果我是
我正在尝试了解如何从联接中仅选择记录上的最新日期。我的 People 实体与 Membership 实体相结合。我的成员(member)实体有一个 RefMembershipStatus 实体。我试图
我目前正在这样。 final CriteriaBuilder builder = ...; final boolean flag = ...; if (flag) { builder.isTr
我有这样的 SQL 语句: SELECT * FROM person inner join (select max(validityId) as maxID from person group by
我是一名优秀的程序员,十分优秀!