【问题标题】:Can I use HQL with JPA's @Query annotation?我可以将 HQL 与 JPA 的 @Query 注释一起使用吗?
【发布时间】:2020-01-18 13:05:03
【问题描述】:

我有两个相同的查询。一个由entityManager.createQuery() 运行,另一个作为PagingAndSortingRepository 中的@Query 注释运行。 entityManager 查询运行良好,但 @Query 注解中的相同查询返回错误。

这可能是因为 @Query 注释将查询作为 JPQL 执行,而 entityManager.createQuery() 将查询作为 HQL 执行?

这里有两个例子:

@Query(不起作用)

@Repository
public interface UserRepository extends PagingAndSortingRepository<User, UUID> {
    @Query("select p.user from Perspective p where p.organisation.id = 'c25c86a0-0d8e-4beb-9ba7-e38d932b8410'")
    List<User> findUsers();
}
could not resolve property: lastname of: org.jembi.appstore.service.entities.Perspective
// note: lastname is a property of user, not perspective.

entityManager.createQuery(有效)

    @Autowired
    EntityManager entityManager;

    @RequestMapping("/query")
    @ResponseBody
    public void testQuery() {
        Query query = entityManager.createQuery("select p.user from Perspective p where p.organisation.id = 'c25c86a0-0d8e-4beb-9ba7-e38d932b8410'");
        List<User> users = query.getResultList();
        users.forEach(u -> System.out.println(u.getFirstname()));
    }

【问题讨论】:

  • 我删除并重新创建了数据库,它开始正常工作。

标签: java hibernate spring-data-jpa spring-data jpql


【解决方案1】:

这里有几个错误:

  1. 您正在定义 @Param("organisationId"),但没有在任何地方使用它。
  2. 您正在加入用户:join User u,但从不使用它:既未定义与 Perspective 的任何关系,也未在 where 子句中使用。

试试这个查询:

@Query("select p.user from Perspective p where p.organisation.id = :organisationId")
List<User> findUsers(@Param("organisationId") UUID organisationId, Pageable pageable);

【讨论】:

  • 为了简单起见,我暂时硬编码了 UUID。我实际上是在尝试让用户退出,因此要求 p.user,但查询似乎返回了一个“透视”对象。
  • @Spider 不,它正在返回p.user。我的建议有用吗?
  • 这是最接近的答案。似乎我不需要加入。我删除并重新创建了数据库,它开始自动工作,所以我没有实际答案。
【解决方案2】:
@Query("select p.user from Perspective p join User u where p.organisation.id = 'c25c86a0-0d8e-4beb-9ba7-e38d932b8410'")
    List<User> findUsers(@Param("organisationId") UUID organisationId, Pageable pageable);
}

我建议你改写为:

@Query("select p.user from Perspective p join User u where p.organisation.id = ?1")
    List<User> findUsers(String organisationId);
}

为什么是String 而不是UUID?我敢打赌 HQL 不适用于 UUID。 + UUID 可以放在字符串中。
为什么我删除了 Pageable?我在您的查询中找不到您使用第二个参数 [Pageable] 的位置。

【讨论】:

  • 问题不在于记录的发现。我只是暂时硬编码了 UUID。问题是我得到的是一个透视对象而不是一个用户。
  • + 你能在这里添加你在查询中提到的实体吗?
  • 我删除并重新创建了数据库,它开始自动工作,所以我没有实际答案。
  • @Spider 有时你应该在开发程序时这样做)
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2021-11-23
  • 1970-01-01
  • 1970-01-01
  • 2014-10-21
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多