Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in
Toggle navigation
B
beego
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Commits
Issue Boards
Open sidebar
go
beego
Commits
57a9670b
Commit
57a9670b
authored
Aug 14, 2014
by
astaxie
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
migration: reset the up state sql
parent
14cd9e51
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
12 additions
and
7 deletions
+12
-7
migration.go
migration/migration.go
+12
-7
No files found.
migration/migration.go
View file @
57a9670b
...
...
@@ -39,6 +39,7 @@ const (
type
Migrationer
interface
{
Up
()
Down
()
Reset
()
Exec
(
name
,
status
string
)
error
GetCreated
()
int64
}
...
...
@@ -72,6 +73,11 @@ func (m *Migration) Sql(sql string) {
m
.
sqls
=
append
(
m
.
sqls
,
sql
)
}
// Reset the sqls
func
(
m
*
Migration
)
Reset
()
{
m
.
sqls
=
make
([]
string
,
0
)
}
// execute the sql already add in the sql
func
(
m
*
Migration
)
Exec
(
name
,
status
string
)
error
{
o
:=
orm
.
NewOrm
()
...
...
@@ -90,11 +96,11 @@ func (m *Migration) addOrUpdateRecord(name, status string) error {
o
:=
orm
.
NewOrm
()
if
status
==
"down"
{
status
=
"rollback"
p
,
err
:=
o
.
Raw
(
"update migrations set
status = ?, rollback_statements
= ? where name = ?"
)
.
Prepare
()
p
,
err
:=
o
.
Raw
(
"update migrations set
`status` = ?, `rollback_statements` = ?, `created_at`
= ? where name = ?"
)
.
Prepare
()
if
err
!=
nil
{
return
nil
}
_
,
err
=
p
.
Exec
(
status
,
strings
.
Join
(
m
.
sqls
,
"; "
),
name
)
_
,
err
=
p
.
Exec
(
status
,
strings
.
Join
(
m
.
sqls
,
"; "
),
name
,
time
.
Now
()
.
Format
(
M_DB_DATE_FORMAT
)
)
return
err
}
else
{
status
=
"update"
...
...
@@ -102,11 +108,7 @@ func (m *Migration) addOrUpdateRecord(name, status string) error {
if
err
!=
nil
{
return
err
}
t
,
err
:=
time
.
Parse
(
M_DATE_FORMAT
,
m
.
Created
)
if
err
!=
nil
{
return
err
}
_
,
err
=
p
.
Exec
(
name
,
t
.
Format
(
M_DB_DATE_FORMAT
),
strings
.
Join
(
m
.
sqls
,
"; "
),
status
)
_
,
err
=
p
.
Exec
(
name
,
time
.
Now
()
.
Format
(
M_DB_DATE_FORMAT
),
strings
.
Join
(
m
.
sqls
,
"; "
),
status
)
return
err
}
}
...
...
@@ -136,6 +138,7 @@ func Upgrade(lasttime int64) error {
for
_
,
v
:=
range
sm
{
if
v
.
created
>
lasttime
{
beego
.
Info
(
"start upgrade"
,
v
.
name
)
v
.
m
.
Reset
()
v
.
m
.
Up
()
err
:=
v
.
m
.
Exec
(
v
.
name
,
"up"
)
if
err
!=
nil
{
...
...
@@ -156,6 +159,7 @@ func Upgrade(lasttime int64) error {
func
Rollback
(
name
string
)
error
{
if
v
,
ok
:=
migrationMap
[
name
];
ok
{
beego
.
Info
(
"start rollback"
)
v
.
Reset
()
v
.
Down
()
err
:=
v
.
Exec
(
name
,
"down"
)
if
err
!=
nil
{
...
...
@@ -184,6 +188,7 @@ func Reset() error {
continue
}
beego
.
Info
(
"start reset:"
,
v
.
name
)
v
.
m
.
Reset
()
v
.
m
.
Down
()
err
:=
v
.
m
.
Exec
(
v
.
name
,
"down"
)
if
err
!=
nil
{
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment