Jon*_*ard 6 postgresql go golang-migrate
我正在尝试golang-migrate将 sql 文件迁移到我的 postgresql 数据库中。我可能做错了,但是当我运行命令进行迁移时,它说找不到方案:
$ go run ./cmd/ migrate
2022/04/05 16:20:29 no scheme
exit status 1
Run Code Online (Sandbox Code Playgroud)
这是代码:
// package dbschema contains the database schema, migrations, and seeding data.
package dbschema
import (
"context"
_ "embed" // Calls init function.
"fmt"
"log"
"github.com/golang-migrate/migrate/v4"
"github.com/golang-migrate/migrate/v4/database/postgres"
"github.com/jmoiron/sqlx"
"github.com/jonleopard/bootstrap/pkg/sys/database"
_ "github.com/lib/pq"
)
var (
//go:embed sql/000001_schema.up.sql
schemaDoc string
//go:embed sql/seed.sql
seedDoc string
)
// Migrate attempts to bring the schema for db up to date with the migrations
// defined in this package.
func Migrate(ctx context.Context, db *sqlx.DB) error {
if err := database.StatusCheck(ctx, db); err != nil {
return fmt.Errorf("status check database: %w", err)
}
driver, err := postgres.WithInstance(db.DB, &postgres.Config{})
if err != nil {
return fmt.Errorf("Construct Migrate driver: %w", err)
}
m, err := migrate.NewWithDatabaseInstance(schemaDoc, "postgres", driver)
if err != nil {
log.Fatal(err)
}
return m.Up()
}
Run Code Online (Sandbox Code Playgroud)
func NewWithDatabaseInstance(sourceURL string, databaseName string, databaseInstance database.Driver) (*Migrate, error)
Run Code Online (Sandbox Code Playgroud)
所以第一个参数是一个 URL,您将传入脚本本身。NewWithDatabaseInstance调用SchemeFromURL这就是生成您所看到的错误的原因(因为您传递的 url 不包含:)。URL由“方案”和后面的其他信息:组成。
要使用 golang-migrate ,请embed参阅文档中的示例:
//go:embed testdata/migrations/*.sql
var fs embed.FS
func main() {
d, err := iofs.New(fs, "testdata/migrations")
if err != nil {
log.Fatal(err)
}
m, err := migrate.NewWithSourceInstance("iofs", d, "postgres://postgres@localhost/postgres?sslmode=disable")
if err != nil {
log.Fatal(err)
}
err = m.Up()
if err != nil {
// ...
}
// ...
}
Run Code Online (Sandbox Code Playgroud)
您会注意到,这传递的是一个文件夹(作为embed.FS)而不是单个文件。这是因为golang-migrate它旨在应用多个迁移,而不是仅针对数据库运行单个脚本。您应该能够使用类似的东西:
//go:embed sql/*.sql
var schemaFs embed.FS
...
d, err := iofs.New(fs, "sql") // Get migrations from sql folder
if err != nil {
log.Fatal(err)
}
m, err := migrate.NewWithInstance("iofs", d, "postgres", driver)
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
3954 次 |
| 最近记录: |