Fix existing code for new hibernate sanity checks.

This commit is contained in:
Kavin 2023-04-26 12:00:46 +01:00
parent c298499a30
commit f42a006d81
No known key found for this signature in database
GPG key ID: 49451E4482CC5BCD

View file

@ -109,14 +109,14 @@ public class FeedHandlers {
CriteriaQuery<Video> criteria = cb.createQuery(Video.class); CriteriaQuery<Video> criteria = cb.createQuery(Video.class);
var root = criteria.from(Video.class); var root = criteria.from(Video.class);
root.fetch("channel", JoinType.RIGHT); root.fetch("channel", JoinType.RIGHT);
var subquery = criteria.subquery(User.class); var subquery = criteria.subquery(String.class);
var subroot = subquery.from(User.class); var subroot = subquery.from(User.class);
subquery.select(subroot.get("subscribed_ids")) subquery.select(subroot.get("subscribed_ids"))
.where(cb.equal(subroot.get("id"), user.getId())); .where(cb.equal(subroot.get("id"), user.getId()));
criteria.select(root) criteria.select(root)
.where( .where(
root.get("channel").in(subquery) root.get("channel").get("uploader_id").in(subquery)
) )
.orderBy(cb.desc(root.get("uploaded"))); .orderBy(cb.desc(root.get("uploaded")));
@ -162,14 +162,14 @@ public class FeedHandlers {
CriteriaQuery<Video> criteria = cb.createQuery(Video.class); CriteriaQuery<Video> criteria = cb.createQuery(Video.class);
var root = criteria.from(Video.class); var root = criteria.from(Video.class);
root.fetch("channel", JoinType.RIGHT); root.fetch("channel", JoinType.RIGHT);
var subquery = criteria.subquery(User.class); var subquery = criteria.subquery(String.class);
var subroot = subquery.from(User.class); var subroot = subquery.from(User.class);
subquery.select(subroot.get("subscribed_ids")) subquery.select(subroot.get("subscribed_ids"))
.where(cb.equal(subroot.get("id"), user.getId())); .where(cb.equal(subroot.get("id"), user.getId()));
criteria.select(root) criteria.select(root)
.where( .where(
root.get("channel").in(subquery) root.get("channel").get("uploader_id").in(subquery)
) )
.orderBy(cb.desc(root.get("uploaded"))); .orderBy(cb.desc(root.get("uploaded")));