forked from GuiaBolso/darwin
-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy pathdoc.go
82 lines (66 loc) · 1.9 KB
/
doc.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
/*
Package darwin provides a database schema evolution api for Go. The purpose of
this library is just be a library. You can implement your own way of building
the migration list. It is not recommended to put more than one database change
per migration, if some migration fail, you exactly what statement caused the
error. Also only postgres correctly handle rollback in DDL transactions.
The best way to version your migrations is like this: 1.0, 1.1, 1.2
Please read the following posts for more information on the design principles
if this package.
https://flywaydb.org/documentation/faq#downgrade
https://flywaydb.org/documentation/faq#rollback
https://flywaydb.org/documentation/faq#hot-fixes
Given this file:
-- Version: 1.1
-- Description: Create table users
CREATE TABLE users (
user_id UUID,
name TEXT,
email TEXT UNIQUE,
roles TEXT[],
password_hash TEXT,
date_created TIMESTAMP,
date_updated TIMESTAMP,
PRIMARY KEY (user_id)
);
-- Version: 1.2
-- Description: Create table products
CREATE TABLE products (
product_id UUID,
name TEXT,
cost INT,
quantity INT,
date_created TIMESTAMP,
date_updated TIMESTAMP,
PRIMARY KEY (product_id)
);
You can write this code:
package main
import (
"database/sql"
"log"
"github.com/ardanlabs/darwin/v3"
"github.com/ardanlabs/darwin/v3/dialects/postgres"
"github.com/ardanlabs/darwin/v3/drivers/generic"
_ "github.com/go-sql-driver/mysql"
)
var (
//go:embed sql/schema.sql
schemaDoc string
)
func main() {
db, err := sql.Open("mysql", "root:@/darwin")
if err != nil {
log.Fatal(err)
}
driver, err := generic.New(db.DB, postgres.Dialect{})
if err != nil {
return fmt.Errorf("construct darwin driver: %w", err)
}
d := darwin.New(driver, darwin.ParseMigrations(schemaDoc))
if err := d.Migrate(); err != nil {
log.Println(err)
}
}
*/
package darwin