diff options
author | Lauris BH <lauris@nix.lv> | 2020-01-31 08:57:19 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-01-31 08:57:19 +0200 |
commit | b3d8e2d4f7a0ebf768ab6bcb102755839a6b9311 (patch) | |
tree | d06d78f4a74aa5887360442397531d61199bf805 /models/migrations | |
parent | 159732dcb7420699245ef8410fff22002653d5b0 (diff) | |
download | gitea-b3d8e2d4f7a0ebf768ab6bcb102755839a6b9311.tar.gz gitea-b3d8e2d4f7a0ebf768ab6bcb102755839a6b9311.zip |
Update topics repo count when deleting repository (#10051)
* Update topics repo count when deleting repository
* Add migration to fix incorrect data
* Optimize to use single update to recalculate values
Diffstat (limited to 'models/migrations')
-rw-r--r-- | models/migrations/migrations.go | 2 | ||||
-rw-r--r-- | models/migrations/v126.go | 25 |
2 files changed, 27 insertions, 0 deletions
diff --git a/models/migrations/migrations.go b/models/migrations/migrations.go index 286e809abb..99104906be 100644 --- a/models/migrations/migrations.go +++ b/models/migrations/migrations.go @@ -306,6 +306,8 @@ var migrations = []Migration{ NewMigration("Add columns to user and repository", addUserRepoMissingColumns), // v125 -> v126 NewMigration("Add some columns on review for migration", addReviewMigrateInfo), + // v126 -> v127 + NewMigration("Fix topic repository count", fixTopicRepositoryCount), } // Migrate database to current version diff --git a/models/migrations/v126.go b/models/migrations/v126.go new file mode 100644 index 0000000000..bce13a61bd --- /dev/null +++ b/models/migrations/v126.go @@ -0,0 +1,25 @@ +// Copyright 2020 The Gitea Authors. All rights reserved. +// Use of this source code is governed by a MIT-style +// license that can be found in the LICENSE file. + +package migrations + +import ( + "xorm.io/builder" + "xorm.io/xorm" +) + +func fixTopicRepositoryCount(x *xorm.Engine) error { + _, err := x.Exec(builder.Delete(builder.NotIn("`repo_id`", builder.Select("`id`").From("`repository`"))).From("`repo_topic`")) + if err != nil { + return err + } + + _, err = x.Exec(builder.Update( + builder.Eq{ + "`repo_count`": builder.Select("count(*)").From("`repo_topic`").Where(builder.Eq{ + "`repo_topic`.`topic_id`": builder.Expr("`topic`.`id`"), + }), + }).From("`topic`").Where(builder.Eq{"'1'": "1"})) + return err +} |