我有一个Tuple查询正在加载一些值和一个关系(连接)计数 . 我试图获得第三列基于来自该连接的选择案例值,无论连接集合是否包含某些值,但我真的很挣扎 .
一般要点是用户可以通过UserFavorite对象来收藏资产 . 我想选择3件事:
1)资产ID 2)它被收藏的次数3 **)该资产是否已被请求查询的用户收藏
在SQL领域,我这样做:
select distinct a.asset_id, count(u.asset_id) as favorite_count, case when u.user_id in (XXXX) then 1 else 0 end as is_favorite_for_user from asset a left join user_favorite u on (a.asset_id = u.asset_id) group by a.asset_id;
下面的元组查询的前两部分工作正常,但我无法得到其余部分:
Root<Asset> assetRoot = assetQuery.from(Asset.class);
SetJoin<Asset, UserFavorite> userFavoriteJoin = assetRoot.join(Asset_.userFavorites, JoinType.LEFT);
assetQuery.select(criteriaBuilder.tuple(
assetRoot.get(Asset_.assetId),
criteriaBuilder.count(userFavoriteJoin)
));
assetQuery.distinct(true);
assetQuery.groupBy(assetRoot.get(Asset_.assetId));
我无法弄清楚如何在JPA Criteria中执行select case / in语句 . 有什么想法吗?
有没有比select / case更好的方法呢?
1 回答
你试过跟随吗?