使用 Spring Data JPA 检查是否存在多个 ID

Check existence of multiple IDs with Spring Data JPA

类似于内置方法 existsById 我想使用 Spring Data JPA 的 existsAllById 方法。为此,我将以下方法添加到存储库 interface.

@Query(
  "select case when (count(thing) = size(:ids)) then true else false end " +
  "from Thing thing " +
  "where thing.id in :ids")
boolean existsAllById(@Param("ids") Set<UUID> ids);

但是,Hibernate 似乎不喜欢我对 size 的使用,并向我报告此错误:

Caused by: org.hibernate.hql.internal.ast.QuerySyntaxException: Unexpected expression ? found for collection function size [select case when (count(trhing) = size(:ids)) then true else false end from com.example.Thing resource where thing.id in :ids] at org.hibernate.hql.internal.ast.QuerySyntaxException.convert(QuerySyntaxException.java:74) at org.hibernate.hql.internal.ast.ErrorTracker.throwQueryException(ErrorTracker.java:93) at org.hibernate.hql.internal.ast.QueryTranslatorImpl.analyze(QueryTranslatorImpl.java:282) at org.hibernate.hql.internal.ast.QueryTranslatorImpl.doCompile(QueryTranslatorImpl.java:192) at org.hibernate.hql.internal.ast.QueryTranslatorImpl.compile(QueryTranslatorImpl.java:144) at org.hibernate.engine.query.spi.HQLQueryPlan.(HQLQueryPlan.java:113) at org.hibernate.engine.query.spi.HQLQueryPlan.(HQLQueryPlan.java:73) at org.hibernate.engine.query.spi.QueryPlanCache.getHQLQueryPlan(QueryPlanCache.java:162) at org.hibernate.internal.AbstractSharedSessionContract.getQueryPlan(AbstractSharedSessionContract.java:613) at org.hibernate.internal.AbstractSharedSessionContract.createQuery(AbstractSharedSessionContract.java:725)

如何修复此查询?使用 Spring Data JPA 检查多个 ID 是否存在的最佳方法是什么?

您可以计算找到的项目的数量,然后将其与输入的大小进行比较。

注意,在这里使用 Set<> 来防止重复破坏计数。

Integer countAllByIdIn(Set<UUID> ids);

default boolean existsAllById(Set<UUID> ids) {
    return countAllByIdIn(ids).equals(ids.size());
} 

您也可以这样做,关键字是 existsAll:

Boolean existsAllByIdIn(Set<UUID> ids);