summaryrefslogtreecommitdiffstats
path: root/models/packages
diff options
context:
space:
mode:
authorKN4CK3R <admin@oldschoolhack.me>2024-04-20 13:07:00 +0200
committerGergely Nagy <forgejo@gergo.csillger.hu>2024-04-21 16:28:16 +0200
commit27f459b63b1eecdb4487a3aa15d1e6f38d16e090 (patch)
treec856eba5f8bf72127e99e3b9f1fedb44ee317828 /models/packages
parentUse action user as the trigger user of schedules (#30581) (diff)
downloadforgejo-27f459b63b1eecdb4487a3aa15d1e6f38d16e090.tar.xz
forgejo-27f459b63b1eecdb4487a3aa15d1e6f38d16e090.zip
Fix package list performance (#30520)
Fixes #28255 The new query uses the id field to sort by "newer". This most not be correct (usually it is) but it's faster (see #28255). If someone has a better idea, please propose changes. Co-authored-by: Giteabot <teabot@gitea.io> (cherry picked from commit b06aac40e6552b0ce1f7b8a92c977fcc27566f68)
Diffstat (limited to 'models/packages')
-rw-r--r--models/packages/package_version.go22
1 files changed, 11 insertions, 11 deletions
diff --git a/models/packages/package_version.go b/models/packages/package_version.go
index 505dbaa0a5..278e8e3a86 100644
--- a/models/packages/package_version.go
+++ b/models/packages/package_version.go
@@ -287,9 +287,10 @@ func (opts *PackageSearchOptions) configureOrderBy(e db.Engine) {
// SearchVersions gets all versions of packages matching the search options
func SearchVersions(ctx context.Context, opts *PackageSearchOptions) ([]*PackageVersion, int64, error) {
sess := db.GetEngine(ctx).
- Where(opts.ToConds()).
+ Select("package_version.*").
Table("package_version").
- Join("INNER", "package", "package.id = package_version.package_id")
+ Join("INNER", "package", "package.id = package_version.package_id").
+ Where(opts.ToConds())
opts.configureOrderBy(sess)
@@ -304,19 +305,18 @@ func SearchVersions(ctx context.Context, opts *PackageSearchOptions) ([]*Package
// SearchLatestVersions gets the latest version of every package matching the search options
func SearchLatestVersions(ctx context.Context, opts *PackageSearchOptions) ([]*PackageVersion, int64, error) {
- cond := opts.ToConds().
- And(builder.Expr("pv2.id IS NULL"))
-
- joinCond := builder.Expr("package_version.package_id = pv2.package_id AND (package_version.created_unix < pv2.created_unix OR (package_version.created_unix = pv2.created_unix AND package_version.id < pv2.id))")
- if opts.IsInternal.Has() {
- joinCond = joinCond.And(builder.Eq{"pv2.is_internal": opts.IsInternal.Value()})
- }
+ in := builder.
+ Select("MAX(package_version.id)").
+ From("package_version").
+ InnerJoin("package", "package.id = package_version.package_id").
+ Where(opts.ToConds()).
+ GroupBy("package_version.package_id")
sess := db.GetEngine(ctx).
+ Select("package_version.*").
Table("package_version").
- Join("LEFT", "package_version pv2", joinCond).
Join("INNER", "package", "package.id = package_version.package_id").
- Where(cond)
+ Where(builder.In("package_version.id", in))
opts.configureOrderBy(sess)