From 84b7d29d34e0d51e0c67e2e35803e8e611da7965 Mon Sep 17 00:00:00 2001 From: Andrey Nering Date: Fri, 6 Jan 2017 13:14:33 -0200 Subject: Create missing database indexes (#596) --- models/action.go | 10 +++++----- models/admin.go | 2 +- models/issue.go | 30 +++++++++++++++--------------- models/issue_comment.go | 6 +++--- models/login_source.go | 6 +++--- models/org.go | 2 +- models/pull.go | 12 ++++++------ models/release.go | 10 +++++----- models/repo.go | 14 +++++++------- models/repo_mirror.go | 8 ++++---- models/token.go | 8 ++++---- models/user.go | 8 ++++---- models/webhook.go | 12 ++++++------ 13 files changed, 64 insertions(+), 64 deletions(-) (limited to 'models') diff --git a/models/action.go b/models/action.go index 8b3d82b4d6..112e9ec7b9 100644 --- a/models/action.go +++ b/models/action.go @@ -71,19 +71,19 @@ func init() { // used in template render. type Action struct { ID int64 `xorm:"pk autoincr"` - UserID int64 // Receiver user id. + UserID int64 `xorm:"INDEX"` // Receiver user id. OpType ActionType - ActUserID int64 // Action user id. + ActUserID int64 `xorm:"INDEX"` // Action user id. ActUserName string // Action user name. ActAvatar string `xorm:"-"` - RepoID int64 + RepoID int64 `xorm:"INDEX"` RepoUserName string RepoName string RefName string - IsPrivate bool `xorm:"NOT NULL DEFAULT false"` + IsPrivate bool `xorm:"INDEX NOT NULL DEFAULT false"` Content string `xorm:"TEXT"` Created time.Time `xorm:"-"` - CreatedUnix int64 + CreatedUnix int64 `xorm:"INDEX"` } // BeforeInsert will be invoked by XORM before inserting a record diff --git a/models/admin.go b/models/admin.go index 058e9be8a8..9447ef67ea 100644 --- a/models/admin.go +++ b/models/admin.go @@ -32,7 +32,7 @@ type Notice struct { Type NoticeType Description string `xorm:"TEXT"` Created time.Time `xorm:"-"` - CreatedUnix int64 + CreatedUnix int64 `xorm:"INDEX"` } // BeforeInsert is invoked from XORM before inserting an object of this type. diff --git a/models/issue.go b/models/issue.go index 315c91e159..b8f23d5948 100644 --- a/models/issue.go +++ b/models/issue.go @@ -34,29 +34,29 @@ type Issue struct { RepoID int64 `xorm:"INDEX UNIQUE(repo_index)"` Repo *Repository `xorm:"-"` Index int64 `xorm:"UNIQUE(repo_index)"` // Index in one repository. - PosterID int64 - Poster *User `xorm:"-"` - Title string `xorm:"name"` - Content string `xorm:"TEXT"` - RenderedContent string `xorm:"-"` - Labels []*Label `xorm:"-"` - MilestoneID int64 - Milestone *Milestone `xorm:"-"` + PosterID int64 `xorm:"INDEX"` + Poster *User `xorm:"-"` + Title string `xorm:"name"` + Content string `xorm:"TEXT"` + RenderedContent string `xorm:"-"` + Labels []*Label `xorm:"-"` + MilestoneID int64 `xorm:"INDEX"` + Milestone *Milestone `xorm:"-"` Priority int - AssigneeID int64 - Assignee *User `xorm:"-"` - IsClosed bool + AssigneeID int64 `xorm:"INDEX"` + Assignee *User `xorm:"-"` + IsClosed bool `xorm:"INDEX"` IsRead bool `xorm:"-"` - IsPull bool // Indicates whether is a pull request or not. + IsPull bool `xorm:"INDEX"` // Indicates whether is a pull request or not. PullRequest *PullRequest `xorm:"-"` NumComments int Deadline time.Time `xorm:"-"` - DeadlineUnix int64 + DeadlineUnix int64 `xorm:"INDEX"` Created time.Time `xorm:"-"` - CreatedUnix int64 + CreatedUnix int64 `xorm:"INDEX"` Updated time.Time `xorm:"-"` - UpdatedUnix int64 + UpdatedUnix int64 `xorm:"INDEX"` Attachments []*Attachment `xorm:"-"` Comments []*Comment `xorm:"-"` diff --git a/models/issue_comment.go b/models/issue_comment.go index 22c1e8cf91..73c9db1cdb 100644 --- a/models/issue_comment.go +++ b/models/issue_comment.go @@ -53,7 +53,7 @@ const ( type Comment struct { ID int64 `xorm:"pk autoincr"` Type CommentType - PosterID int64 + PosterID int64 `xorm:"INDEX"` Poster *User `xorm:"-"` IssueID int64 `xorm:"INDEX"` CommitID int64 @@ -62,9 +62,9 @@ type Comment struct { RenderedContent string `xorm:"-"` Created time.Time `xorm:"-"` - CreatedUnix int64 + CreatedUnix int64 `xorm:"INDEX"` Updated time.Time `xorm:"-"` - UpdatedUnix int64 + UpdatedUnix int64 `xorm:"INDEX"` // Reference issue in commit message CommitSHA string `xorm:"VARCHAR(40)"` diff --git a/models/login_source.go b/models/login_source.go index 58e0e88b3e..3fe5e172e3 100644 --- a/models/login_source.go +++ b/models/login_source.go @@ -120,13 +120,13 @@ type LoginSource struct { ID int64 `xorm:"pk autoincr"` Type LoginType Name string `xorm:"UNIQUE"` - IsActived bool `xorm:"NOT NULL DEFAULT false"` + IsActived bool `xorm:"INDEX NOT NULL DEFAULT false"` Cfg core.Conversion `xorm:"TEXT"` Created time.Time `xorm:"-"` - CreatedUnix int64 + CreatedUnix int64 `xorm:"INDEX"` Updated time.Time `xorm:"-"` - UpdatedUnix int64 + UpdatedUnix int64 `xorm:"INDEX"` } // BeforeInsert is invoked from XORM before inserting an object of this type. diff --git a/models/org.go b/models/org.go index 7fbd790f5b..7d64d5a917 100644 --- a/models/org.go +++ b/models/org.go @@ -255,7 +255,7 @@ type OrgUser struct { ID int64 `xorm:"pk autoincr"` UID int64 `xorm:"INDEX UNIQUE(s)"` OrgID int64 `xorm:"INDEX UNIQUE(s)"` - IsPublic bool + IsPublic bool `xorm:"INDEX"` IsOwner bool NumTeams int } diff --git a/models/pull.go b/models/pull.go index 6231b71cb7..8661fa3aa8 100644 --- a/models/pull.go +++ b/models/pull.go @@ -54,21 +54,21 @@ type PullRequest struct { Issue *Issue `xorm:"-"` Index int64 - HeadRepoID int64 + HeadRepoID int64 `xorm:"INDEX"` HeadRepo *Repository `xorm:"-"` - BaseRepoID int64 + BaseRepoID int64 `xorm:"INDEX"` BaseRepo *Repository `xorm:"-"` HeadUserName string HeadBranch string BaseBranch string MergeBase string `xorm:"VARCHAR(40)"` - HasMerged bool - MergedCommitID string `xorm:"VARCHAR(40)"` - MergerID int64 + HasMerged bool `xorm:"INDEX"` + MergedCommitID string `xorm:"VARCHAR(40)"` + MergerID int64 `xorm:"INDEX"` Merger *User `xorm:"-"` Merged time.Time `xorm:"-"` - MergedUnix int64 + MergedUnix int64 `xorm:"INDEX"` } // BeforeUpdate is invoked from XORM before updating an object of this type. diff --git a/models/release.go b/models/release.go index 28ba6c1d68..67ef81e21c 100644 --- a/models/release.go +++ b/models/release.go @@ -23,11 +23,11 @@ import ( // Release represents a release of repository. type Release struct { ID int64 `xorm:"pk autoincr"` - RepoID int64 `xorm:"index unique(n)"` + RepoID int64 `xorm:"INDEX UNIQUE(n)"` Repo *Repository `xorm:"-"` - PublisherID int64 - Publisher *User `xorm:"-"` - TagName string `xorm:"index unique(n)"` + PublisherID int64 `xorm:"INDEX"` + Publisher *User `xorm:"-"` + TagName string `xorm:"INDEX UNIQUE(n)"` LowerTagName string Target string Title string @@ -39,7 +39,7 @@ type Release struct { IsPrerelease bool Created time.Time `xorm:"-"` - CreatedUnix int64 + CreatedUnix int64 `xorm:"INDEX"` } // BeforeInsert is invoked from XORM before inserting an object of this type. diff --git a/models/repo.go b/models/repo.go index 85807e3a4b..4acb0d736e 100644 --- a/models/repo.go +++ b/models/repo.go @@ -193,10 +193,10 @@ type Repository struct { NumOpenMilestones int `xorm:"-"` NumTags int `xorm:"-"` - IsPrivate bool - IsBare bool + IsPrivate bool `xorm:"INDEX"` + IsBare bool `xorm:"INDEX"` - IsMirror bool + IsMirror bool `xorm:"INDEX"` *Mirror `xorm:"-"` // Advanced settings @@ -211,14 +211,14 @@ type Repository struct { ExternalMetas map[string]string `xorm:"-"` EnablePulls bool `xorm:"NOT NULL DEFAULT true"` - IsFork bool `xorm:"NOT NULL DEFAULT false"` - ForkID int64 + IsFork bool `xorm:"INDEX NOT NULL DEFAULT false"` + ForkID int64 `xorm:"INDEX"` BaseRepo *Repository `xorm:"-"` Created time.Time `xorm:"-"` - CreatedUnix int64 + CreatedUnix int64 `xorm:"INDEX"` Updated time.Time `xorm:"-"` - UpdatedUnix int64 + UpdatedUnix int64 `xorm:"INDEX"` } // BeforeInsert is invoked from XORM before inserting an object of this type. diff --git a/models/repo_mirror.go b/models/repo_mirror.go index 2cedf69d70..abe70de1ab 100644 --- a/models/repo_mirror.go +++ b/models/repo_mirror.go @@ -24,16 +24,16 @@ var MirrorQueue = sync.NewUniqueQueue(setting.Repository.MirrorQueueLength) // Mirror represents mirror information of a repository. type Mirror struct { - ID int64 `xorm:"pk autoincr"` - RepoID int64 + ID int64 `xorm:"pk autoincr"` + RepoID int64 `xorm:"INDEX"` Repo *Repository `xorm:"-"` Interval int // Hour. EnablePrune bool `xorm:"NOT NULL DEFAULT true"` Updated time.Time `xorm:"-"` - UpdatedUnix int64 + UpdatedUnix int64 `xorm:"INDEX"` NextUpdate time.Time `xorm:"-"` - NextUpdateUnix int64 + NextUpdateUnix int64 `xorm:"INDEX"` address string `xorm:"-"` } diff --git a/models/token.go b/models/token.go index 6b2898a49d..b2e0a28a5a 100644 --- a/models/token.go +++ b/models/token.go @@ -21,11 +21,11 @@ type AccessToken struct { Sha1 string `xorm:"UNIQUE VARCHAR(40)"` Created time.Time `xorm:"-"` - CreatedUnix int64 + CreatedUnix int64 `xorm:"INDEX"` Updated time.Time `xorm:"-"` // Note: Updated must below Created for AfterSet. - UpdatedUnix int64 - HasRecentActivity bool `xorm:"-"` - HasUsed bool `xorm:"-"` + UpdatedUnix int64 `xorm:"INDEX"` + HasRecentActivity bool `xorm:"-"` + HasUsed bool `xorm:"-"` } // BeforeInsert will be invoked by XORM before inserting a record representing this object. diff --git a/models/user.go b/models/user.go index 1dbd63dce0..201d8c48fa 100644 --- a/models/user.go +++ b/models/user.go @@ -90,11 +90,11 @@ type User struct { Salt string `xorm:"VARCHAR(10)"` Created time.Time `xorm:"-"` - CreatedUnix int64 + CreatedUnix int64 `xorm:"INDEX"` Updated time.Time `xorm:"-"` - UpdatedUnix int64 + UpdatedUnix int64 `xorm:"INDEX"` LastLogin time.Time `xorm:"-"` - LastLoginUnix int64 + LastLoginUnix int64 `xorm:"INDEX"` // Remember visibility choice for convenience, true for private LastRepoVisibility bool @@ -102,7 +102,7 @@ type User struct { MaxRepoCreation int `xorm:"NOT NULL DEFAULT -1"` // Permissions - IsActive bool // Activate primary email + IsActive bool `xorm:"INDEX"` // Activate primary email IsAdmin bool AllowGitHook bool AllowImportLocal bool // Allow migrate repository by local path diff --git a/models/webhook.go b/models/webhook.go index 2da88de2a4..c9c3c21a46 100644 --- a/models/webhook.go +++ b/models/webhook.go @@ -91,24 +91,24 @@ const ( // Webhook represents a web hook object. type Webhook struct { - ID int64 `xorm:"pk autoincr"` - RepoID int64 - OrgID int64 + ID int64 `xorm:"pk autoincr"` + RepoID int64 `xorm:"INDEX"` + OrgID int64 `xorm:"INDEX"` URL string `xorm:"url TEXT"` ContentType HookContentType Secret string `xorm:"TEXT"` Events string `xorm:"TEXT"` *HookEvent `xorm:"-"` IsSSL bool `xorm:"is_ssl"` - IsActive bool + IsActive bool `xorm:"INDEX"` HookTaskType HookTaskType Meta string `xorm:"TEXT"` // store hook-specific attributes LastStatus HookStatus // Last delivery status Created time.Time `xorm:"-"` - CreatedUnix int64 + CreatedUnix int64 `xorm:"INDEX"` Updated time.Time `xorm:"-"` - UpdatedUnix int64 + UpdatedUnix int64 `xorm:"INDEX"` } // BeforeInsert will be invoked by XORM before inserting a record -- cgit v1.2.3