mirror of
https://github.com/TeamPiped/Piped-Backend.git
synced 2024-12-13 13:50:28 +05:30
Optimize feed query by reducing join on users.
This commit is contained in:
parent
bfabe1e9ba
commit
d93f2f360b
@ -864,14 +864,16 @@ public class ResponseHelper {
|
|||||||
// Get all videos from subscribed channels, with channel info
|
// Get all videos from subscribed channels, with channel info
|
||||||
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);
|
||||||
var userRoot = criteria.from(User.class);
|
|
||||||
root.fetch("channel", JoinType.INNER);
|
root.fetch("channel", JoinType.INNER);
|
||||||
|
var subquery = criteria.subquery(User.class);
|
||||||
|
var subroot = subquery.from(User.class);
|
||||||
|
subquery.select(subroot.get("subscribed_ids"))
|
||||||
|
.where(cb.equal(subroot.get("id"), user.getId()));
|
||||||
|
|
||||||
criteria.select(root)
|
criteria.select(root)
|
||||||
.where(cb.and(
|
.where(
|
||||||
cb.isMember(root.get("channel"), userRoot.<Collection<String>>get("subscribed_ids")),
|
root.get("channel").in(subquery)
|
||||||
cb.equal(userRoot.get("id"), user.getId())
|
)
|
||||||
))
|
|
||||||
.orderBy(cb.desc(root.get("uploaded")));
|
.orderBy(cb.desc(root.get("uploaded")));
|
||||||
|
|
||||||
List<StreamItem> feedItems = new ObjectArrayList<>();
|
List<StreamItem> feedItems = new ObjectArrayList<>();
|
||||||
@ -915,14 +917,15 @@ public class ResponseHelper {
|
|||||||
// Get all videos from subscribed channels, with channel info
|
// Get all videos from subscribed channels, with channel info
|
||||||
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);
|
||||||
var userRoot = criteria.from(User.class);
|
var subquery = criteria.subquery(User.class);
|
||||||
root.fetch("channel", JoinType.INNER);
|
var subroot = subquery.from(User.class);
|
||||||
|
subquery.select(subroot.get("subscribed_ids"))
|
||||||
|
.where(cb.equal(subroot.get("id"), user.getId()));
|
||||||
|
|
||||||
criteria.select(root)
|
criteria.select(root)
|
||||||
.where(cb.and(
|
.where(
|
||||||
cb.isMember(root.get("channel"), userRoot.<Collection<String>>get("subscribed_ids")),
|
root.get("channel").in(subquery)
|
||||||
cb.equal(userRoot.get("id"), user.getId())
|
)
|
||||||
))
|
|
||||||
.orderBy(cb.desc(root.get("uploaded")));
|
.orderBy(cb.desc(root.get("uploaded")));
|
||||||
|
|
||||||
List<Video> videos = s.createQuery(criteria)
|
List<Video> videos = s.createQuery(criteria)
|
||||||
@ -1189,12 +1192,14 @@ public class ResponseHelper {
|
|||||||
CriteriaBuilder cb = s.getCriteriaBuilder();
|
CriteriaBuilder cb = s.getCriteriaBuilder();
|
||||||
var query = cb.createQuery(me.kavin.piped.utils.obj.db.Channel.class);
|
var query = cb.createQuery(me.kavin.piped.utils.obj.db.Channel.class);
|
||||||
var root = query.from(me.kavin.piped.utils.obj.db.Channel.class);
|
var root = query.from(me.kavin.piped.utils.obj.db.Channel.class);
|
||||||
var userRoot = query.from(User.class);
|
var subquery = query.subquery(User.class);
|
||||||
query.select(root);
|
var subroot = subquery.from(User.class);
|
||||||
query.where(cb.and(
|
|
||||||
cb.isMember(root.get("uploader_id"), userRoot.<Collection<String>>get("subscribed_ids")),
|
subquery.select(subroot.get("subscribed_ids"))
|
||||||
cb.equal(userRoot.get("id"), user.getId())
|
.where(cb.equal(subroot.get("id"), user.getId()));
|
||||||
));
|
|
||||||
|
query.select(root)
|
||||||
|
.where(root.get("uploader_id").in(subquery));
|
||||||
|
|
||||||
var channels = s.createQuery(query).list();
|
var channels = s.createQuery(query).list();
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user