mirror of
https://github.com/beego/bee.git
synced 2024-11-22 15:10:54 +00:00
change migration schema and getting cmd line parameters
This commit is contained in:
parent
e2ce0300a6
commit
8d82b27502
30
migrate.go
30
migrate.go
@ -44,13 +44,16 @@ const (
|
|||||||
TMP_DIR = "temp"
|
TMP_DIR = "temp"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
var mDriver docValue
|
||||||
|
var mConn docValue
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
cmdMigrate.Run = runMigration
|
cmdMigrate.Run = runMigration
|
||||||
|
cmdMigrate.Flag.Var(&mDriver, "driver", "database driver: mysql, postgresql, etc.")
|
||||||
|
cmdMigrate.Flag.Var(&mConn, "conn", "connection string used by the driver to connect to a database instance")
|
||||||
}
|
}
|
||||||
|
|
||||||
func runMigration(cmd *Command, args []string) {
|
func runMigration(cmd *Command, args []string) {
|
||||||
//curpath, _ := os.Getwd()
|
|
||||||
|
|
||||||
gopath := os.Getenv("GOPATH")
|
gopath := os.Getenv("GOPATH")
|
||||||
Debugf("gopath:%s", gopath)
|
Debugf("gopath:%s", gopath)
|
||||||
if gopath == "" {
|
if gopath == "" {
|
||||||
@ -59,24 +62,34 @@ func runMigration(cmd *Command, args []string) {
|
|||||||
os.Exit(2)
|
os.Exit(2)
|
||||||
}
|
}
|
||||||
// getting command line arguments
|
// getting command line arguments
|
||||||
connStr := "root:@tcp(127.0.0.1:3306)/sgfas?charset=utf8"
|
if len(args) != 0 {
|
||||||
driver := "mysql"
|
cmd.Flag.Parse(args[1:])
|
||||||
|
}
|
||||||
|
if mDriver == "" {
|
||||||
|
mDriver = "mysql"
|
||||||
|
}
|
||||||
|
if mConn == "" {
|
||||||
|
mConn = "root:@tcp(127.0.0.1:3306)/test"
|
||||||
|
}
|
||||||
|
ColorLog("[INFO] Using '%s' as 'driver'\n", mDriver)
|
||||||
|
ColorLog("[INFO] Using '%s' as 'conn'\n", mConn)
|
||||||
|
driverStr, connStr := string(mDriver), string(mConn)
|
||||||
if len(args) == 0 {
|
if len(args) == 0 {
|
||||||
// run all outstanding migrations
|
// run all outstanding migrations
|
||||||
ColorLog("[INFO] Running all outstanding migrations\n")
|
ColorLog("[INFO] Running all outstanding migrations\n")
|
||||||
migrateUpdate(driver, connStr)
|
migrateUpdate(driverStr, connStr)
|
||||||
} else {
|
} else {
|
||||||
mcmd := args[0]
|
mcmd := args[0]
|
||||||
switch mcmd {
|
switch mcmd {
|
||||||
case "rollback":
|
case "rollback":
|
||||||
ColorLog("[INFO] Rolling back the last migration operation\n")
|
ColorLog("[INFO] Rolling back the last migration operation\n")
|
||||||
migrateRollback(driver, connStr)
|
migrateRollback(driverStr, connStr)
|
||||||
case "reset":
|
case "reset":
|
||||||
ColorLog("[INFO] Reseting all migrations\n")
|
ColorLog("[INFO] Reseting all migrations\n")
|
||||||
migrateReset(driver, connStr)
|
migrateReset(driverStr, connStr)
|
||||||
case "refresh":
|
case "refresh":
|
||||||
ColorLog("[INFO] Refreshing all migrations\n")
|
ColorLog("[INFO] Refreshing all migrations\n")
|
||||||
migrateReset(driver, connStr)
|
migrateReset(driverStr, connStr)
|
||||||
default:
|
default:
|
||||||
ColorLog("[ERRO] Command is missing\n")
|
ColorLog("[ERRO] Command is missing\n")
|
||||||
os.Exit(2)
|
os.Exit(2)
|
||||||
@ -273,6 +286,7 @@ CREATE TABLE migrations (
|
|||||||
name varchar(255) DEFAULT NULL COMMENT 'migration name, unique',
|
name varchar(255) DEFAULT NULL COMMENT 'migration name, unique',
|
||||||
created_at timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT 'date migrated or rolled back',
|
created_at timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT 'date migrated or rolled back',
|
||||||
statements longtext COMMENT 'SQL statements for this migration',
|
statements longtext COMMENT 'SQL statements for this migration',
|
||||||
|
rollback_statements longtext COMMENT 'SQL statment for rolling back migration',
|
||||||
status ENUM('update', 'rollback') COMMENT 'update indicates it is a normal migration while rollback means this migration is rolled back',
|
status ENUM('update', 'rollback') COMMENT 'update indicates it is a normal migration while rollback means this migration is rolled back',
|
||||||
PRIMARY KEY (id_migration),
|
PRIMARY KEY (id_migration),
|
||||||
UNIQUE KEY (name)
|
UNIQUE KEY (name)
|
||||||
|
Loading…
Reference in New Issue
Block a user