mirror of https://github.com/go-gitea/gitea.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
31 lines
994 B
31 lines
994 B
// Copyright 2022 The Gitea Authors. All rights reserved. |
|
// SPDX-License-Identifier: MIT |
|
|
|
package db |
|
|
|
import ( |
|
"context" |
|
|
|
"xorm.io/builder" |
|
) |
|
|
|
// CountOrphanedObjects count subjects with have no existing refobject anymore |
|
func CountOrphanedObjects(ctx context.Context, subject, refObject, joinCond string) (int64, error) { |
|
return GetEngine(ctx). |
|
Table("`"+subject+"`"). |
|
Join("LEFT", "`"+refObject+"`", joinCond). |
|
Where(builder.IsNull{"`" + refObject + "`.id"}). |
|
Select("COUNT(`" + subject + "`.`id`)"). |
|
Count() |
|
} |
|
|
|
// DeleteOrphanedObjects delete subjects with have no existing refobject anymore |
|
func DeleteOrphanedObjects(ctx context.Context, subject, refObject, joinCond string) error { |
|
subQuery := builder.Select("`"+subject+"`.id"). |
|
From("`"+subject+"`"). |
|
Join("LEFT", "`"+refObject+"`", joinCond). |
|
Where(builder.IsNull{"`" + refObject + "`.id"}) |
|
b := builder.Delete(builder.In("id", subQuery)).From("`" + subject + "`") |
|
_, err := GetEngine(ctx).Exec(b) |
|
return err |
|
}
|
|
|