-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmigration.go
109 lines (88 loc) · 1.92 KB
/
migration.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
package main
import (
"os"
"path"
"strings"
)
// 数据库 Migration 表结构
type MigrationRec struct {
Id uint
Migration string
Batch uint
}
type MigrationInfo struct {
Name string
UpFilename string
DownFilename string
upSQL string
downSQL string
}
func (m *MigrationInfo) LoadSQLFile() error {
up, err := os.ReadFile(m.UpFilename)
if err != nil {
return err
}
m.upSQL = string(up)
down, err := os.ReadFile(m.DownFilename)
if err != nil {
return err
}
m.downSQL = string(down)
return nil
}
func (m MigrationInfo) GetUpSQL() string {
return m.upSQL
}
func (m MigrationInfo) GetDownSQL() string {
return m.downSQL
}
type Migrations struct {
names []string
infos map[string]MigrationInfo
}
func (m *Migrations) GetNames() []string {
return m.names
}
func (m *Migrations) GetInfo(name string) MigrationInfo {
return m.infos[name]
}
func LoadMigrations(migrationPath string) (*Migrations, error) {
dirs, err := os.ReadDir(migrationPath)
if err != nil {
return nil, err
}
migrations := &Migrations{
names: make([]string, 0),
infos: make(map[string]MigrationInfo),
}
for _, dir := range dirs {
if dir.IsDir() {
continue
}
filename := dir.Name()
fileExt := strings.ToLower(path.Ext(filename))
if fileExt != ".sql" {
continue
}
migrationName := filename[:len(filename)-4]
isRollback := false
if len(migrationName) > 9 && migrationName[len(migrationName)-9:] == "_rollback" {
isRollback = true
migrationName = migrationName[:len(migrationName)-9]
}
data, exist := migrations.infos[migrationName]
if !exist {
migrations.names = append(migrations.names, migrationName)
data = MigrationInfo{
Name: migrationName,
}
}
if isRollback {
data.DownFilename = path.Join(migrationPath, filename)
} else {
data.UpFilename = path.Join(migrationPath, filename)
}
migrations.infos[migrationName] = data
}
return migrations, nil
}