我正在尝试使用 JPA Criteria API 编写以下 SQL 查询
SELECT * FROM roles WHERE roles.name IN (SELECT users.role FROM users where name="somename");
这对我来说有点过分(我刚刚开始学习 Criteria API)。我得到了这样的东西:
CriteriaBuilder criteriaBuilder = manager.getCriteriaBuilder();
CriteriaQuery<RoleEntity> criteriaQuery = criteriaBuilder.createQuery(RoleEntity.class);
Root<RoleEntity> root = criteriaQuery.from(RoleEntity.class);
Subquery<UserEntity> subquery = criteriaQuery.subquery(UserEntity.class);
Root<UserEntity> subqueryRoot = subquery.from(UserEntity.class);
subquery.where(criteriaBuilder.equal(subqueryRoot.get(UserEntity_.username), username));
subquery.select(subqueryRoot);
我不知道如何把它们放在一起。
最好的问候, 巴特克