mirror of https://github.com/go-gitea/gitea
Perf: add extra index to notification table (#32395)
Index SQL: `CREATE INDEX u_s_uu ON notification(user_id, status, updated_unix);` The naming follows `action.go` in the same dir. I am unsure which version I should add SQL to the migration folder, so I have not modified it. Fix #32390pull/32487/head^2
parent
0aedb03996
commit
ad223000d4
@ -0,0 +1,77 @@ |
|||||||
|
// Copyright 2024 The Gitea Authors. All rights reserved.
|
||||||
|
// SPDX-License-Identifier: MIT
|
||||||
|
|
||||||
|
package v1_23 //nolint
|
||||||
|
|
||||||
|
import ( |
||||||
|
"code.gitea.io/gitea/modules/timeutil" |
||||||
|
|
||||||
|
"xorm.io/xorm" |
||||||
|
"xorm.io/xorm/schemas" |
||||||
|
) |
||||||
|
|
||||||
|
type improveNotificationTableIndicesAction struct { |
||||||
|
ID int64 `xorm:"pk autoincr"` |
||||||
|
UserID int64 `xorm:"NOT NULL"` |
||||||
|
RepoID int64 `xorm:"NOT NULL"` |
||||||
|
|
||||||
|
Status uint8 `xorm:"SMALLINT NOT NULL"` |
||||||
|
Source uint8 `xorm:"SMALLINT NOT NULL"` |
||||||
|
|
||||||
|
IssueID int64 `xorm:"NOT NULL"` |
||||||
|
CommitID string |
||||||
|
CommentID int64 |
||||||
|
|
||||||
|
UpdatedBy int64 `xorm:"NOT NULL"` |
||||||
|
|
||||||
|
CreatedUnix timeutil.TimeStamp `xorm:"created NOT NULL"` |
||||||
|
UpdatedUnix timeutil.TimeStamp `xorm:"updated NOT NULL"` |
||||||
|
} |
||||||
|
|
||||||
|
// TableName sets the name of this table
|
||||||
|
func (*improveNotificationTableIndicesAction) TableName() string { |
||||||
|
return "notification" |
||||||
|
} |
||||||
|
|
||||||
|
// TableIndices implements xorm's TableIndices interface
|
||||||
|
func (*improveNotificationTableIndicesAction) TableIndices() []*schemas.Index { |
||||||
|
indices := make([]*schemas.Index, 0, 8) |
||||||
|
usuuIndex := schemas.NewIndex("u_s_uu", schemas.IndexType) |
||||||
|
usuuIndex.AddColumn("user_id", "status", "updated_unix") |
||||||
|
indices = append(indices, usuuIndex) |
||||||
|
|
||||||
|
// Add the individual indices that were previously defined in struct tags
|
||||||
|
userIDIndex := schemas.NewIndex("idx_notification_user_id", schemas.IndexType) |
||||||
|
userIDIndex.AddColumn("user_id") |
||||||
|
indices = append(indices, userIDIndex) |
||||||
|
|
||||||
|
repoIDIndex := schemas.NewIndex("idx_notification_repo_id", schemas.IndexType) |
||||||
|
repoIDIndex.AddColumn("repo_id") |
||||||
|
indices = append(indices, repoIDIndex) |
||||||
|
|
||||||
|
statusIndex := schemas.NewIndex("idx_notification_status", schemas.IndexType) |
||||||
|
statusIndex.AddColumn("status") |
||||||
|
indices = append(indices, statusIndex) |
||||||
|
|
||||||
|
sourceIndex := schemas.NewIndex("idx_notification_source", schemas.IndexType) |
||||||
|
sourceIndex.AddColumn("source") |
||||||
|
indices = append(indices, sourceIndex) |
||||||
|
|
||||||
|
issueIDIndex := schemas.NewIndex("idx_notification_issue_id", schemas.IndexType) |
||||||
|
issueIDIndex.AddColumn("issue_id") |
||||||
|
indices = append(indices, issueIDIndex) |
||||||
|
|
||||||
|
commitIDIndex := schemas.NewIndex("idx_notification_commit_id", schemas.IndexType) |
||||||
|
commitIDIndex.AddColumn("commit_id") |
||||||
|
indices = append(indices, commitIDIndex) |
||||||
|
|
||||||
|
updatedByIndex := schemas.NewIndex("idx_notification_updated_by", schemas.IndexType) |
||||||
|
updatedByIndex.AddColumn("updated_by") |
||||||
|
indices = append(indices, updatedByIndex) |
||||||
|
|
||||||
|
return indices |
||||||
|
} |
||||||
|
|
||||||
|
func ImproveNotificationTableIndices(x *xorm.Engine) error { |
||||||
|
return x.Sync(&improveNotificationTableIndicesAction{}) |
||||||
|
} |
Loading…
Reference in new issue