Add Primary Key to Topic and RepoTopic (#12639)
Add a primary key to Topic and RepoTopic tables Fix #8920 Signed-off-by: Andrew Thornton <art27@cantab.net>
This commit is contained in:
		
							parent
							
								
									4f8dad37f8
								
							
						
					
					
						commit
						47289344e2
					
				
					 3 changed files with 44 additions and 3 deletions
				
			
		|  | @ -233,6 +233,8 @@ var migrations = []Migration{ | |||
| 	NewMigration("remove issue dependency comments who refer to non existing issues", purgeInvalidDependenciesComments), | ||||
| 	// v149 -> v150
 | ||||
| 	NewMigration("Add Created and Updated to Milestone table", addCreatedAndUpdatedToMilestones), | ||||
| 	// v150 -> v151
 | ||||
| 	NewMigration("add primary key to repo_topic", addPrimaryKeyToRepoTopic), | ||||
| } | ||||
| 
 | ||||
| // GetCurrentDBVersion returns the current db version
 | ||||
|  |  | |||
							
								
								
									
										39
									
								
								models/migrations/v150.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								models/migrations/v150.go
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,39 @@ | |||
| // 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 ( | ||||
| 	"code.gitea.io/gitea/modules/timeutil" | ||||
| 
 | ||||
| 	"xorm.io/xorm" | ||||
| ) | ||||
| 
 | ||||
| func addPrimaryKeyToRepoTopic(x *xorm.Engine) error { | ||||
| 	// Topic represents a topic of repositories
 | ||||
| 	type Topic struct { | ||||
| 		ID          int64  `xorm:"pk autoincr"` | ||||
| 		Name        string `xorm:"UNIQUE VARCHAR(25)"` | ||||
| 		RepoCount   int | ||||
| 		CreatedUnix timeutil.TimeStamp `xorm:"INDEX created"` | ||||
| 		UpdatedUnix timeutil.TimeStamp `xorm:"INDEX updated"` | ||||
| 	} | ||||
| 
 | ||||
| 	// RepoTopic represents associated repositories and topics
 | ||||
| 	type RepoTopic struct { | ||||
| 		RepoID  int64 `xorm:"pk"` | ||||
| 		TopicID int64 `xorm:"pk"` | ||||
| 	} | ||||
| 
 | ||||
| 	sess := x.NewSession() | ||||
| 	defer sess.Close() | ||||
| 	if err := sess.Begin(); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 
 | ||||
| 	recreateTable(sess, &Topic{}) | ||||
| 	recreateTable(sess, &RepoTopic{}) | ||||
| 
 | ||||
| 	return sess.Commit() | ||||
| } | ||||
|  | @ -25,7 +25,7 @@ var topicPattern = regexp.MustCompile(`^[a-z0-9][a-z0-9-]*$`) | |||
| 
 | ||||
| // Topic represents a topic of repositories
 | ||||
| type Topic struct { | ||||
| 	ID          int64 | ||||
| 	ID          int64  `xorm:"pk autoincr"` | ||||
| 	Name        string `xorm:"UNIQUE VARCHAR(25)"` | ||||
| 	RepoCount   int | ||||
| 	CreatedUnix timeutil.TimeStamp `xorm:"INDEX created"` | ||||
|  | @ -34,8 +34,8 @@ type Topic struct { | |||
| 
 | ||||
| // RepoTopic represents associated repositories and topics
 | ||||
| type RepoTopic struct { | ||||
| 	RepoID  int64 `xorm:"UNIQUE(s)"` | ||||
| 	TopicID int64 `xorm:"UNIQUE(s)"` | ||||
| 	RepoID  int64 `xorm:"pk"` | ||||
| 	TopicID int64 `xorm:"pk"` | ||||
| } | ||||
| 
 | ||||
| // ErrTopicNotExist represents an error that a topic is not exist
 | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue