-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdatabase.go
More file actions
60 lines (46 loc) · 1.75 KB
/
database.go
File metadata and controls
60 lines (46 loc) · 1.75 KB
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
//go:generate go tool sqlc-multi-db --engine sqlite:sqlitedb --engine postgres:postgresdb --engine mysql:mysqldb postgresdb/querier.go
package database
import (
"context"
"database/sql"
"fmt"
"strings"
"github.com/kalbasit/sqlc-multi-db/example/pkg/database/mysqldb"
"github.com/kalbasit/sqlc-multi-db/example/pkg/database/postgresdb"
"github.com/kalbasit/sqlc-multi-db/example/pkg/database/sqlitedb"
_ "github.com/go-sql-driver/mysql" // MySQL driver
_ "github.com/jackc/pgx/v5/stdlib" // PostgreSQL driver
_ "github.com/mattn/go-sqlite3" // SQLite driver
)
// Open opens a database connection and returns a Querier.
// URL schemes: sqlite:/, postgresql://, mysql://.
func Open(ctx context.Context, dbURL string) (Querier, error) {
switch {
case strings.HasPrefix(dbURL, "sqlite:"):
path := strings.TrimPrefix(dbURL, "sqlite:")
sdb, err := sql.Open("sqlite3", path)
if err != nil {
return nil, fmt.Errorf("opening sqlite: %w", err)
}
sdb.SetMaxOpenConns(1)
if _, err := sdb.ExecContext(ctx, "PRAGMA foreign_keys = ON"); err != nil {
return nil, fmt.Errorf("enabling foreign keys: %w", err)
}
return &sqliteWrapper{adapter: sqlitedb.NewAdapter(sdb)}, nil
case strings.HasPrefix(dbURL, "postgres://"), strings.HasPrefix(dbURL, "postgresql://"):
sdb, err := sql.Open("pgx", dbURL)
if err != nil {
return nil, fmt.Errorf("opening postgres: %w", err)
}
return &postgresWrapper{adapter: postgresdb.NewAdapter(sdb)}, nil
case strings.HasPrefix(dbURL, "mysql://"):
dsn := strings.TrimPrefix(dbURL, "mysql://")
sdb, err := sql.Open("mysql", dsn)
if err != nil {
return nil, fmt.Errorf("opening mysql: %w", err)
}
return &mysqlWrapper{adapter: mysqldb.NewAdapter(sdb)}, nil
default:
return nil, ErrUnsupportedDriver
}
}