2024-01-12 13:15:30 +08:00
|
|
|
|
package dm
|
|
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
|
"database/sql"
|
|
|
|
|
|
"fmt"
|
|
|
|
|
|
"mayfly-go/internal/db/dbm/dbi"
|
2024-01-19 08:59:35 +00:00
|
|
|
|
"net/url"
|
2024-01-12 13:15:30 +08:00
|
|
|
|
"strings"
|
|
|
|
|
|
)
|
|
|
|
|
|
|
2024-01-24 17:01:17 +08:00
|
|
|
|
func init() {
|
|
|
|
|
|
dbi.Register(dbi.DbTypeDM, new(DmMeta))
|
2024-01-12 13:15:30 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
type DmMeta struct {
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
func (md *DmMeta) GetSqlDb(d *dbi.DbInfo) (*sql.DB, error) {
|
|
|
|
|
|
driverName := "dm"
|
|
|
|
|
|
db := d.Database
|
|
|
|
|
|
var dbParam string
|
|
|
|
|
|
if db != "" {
|
|
|
|
|
|
// dm database可以使用db/schema表示,方便连接指定schema, 若不存在schema则使用默认schema
|
|
|
|
|
|
ss := strings.Split(db, "/")
|
|
|
|
|
|
if len(ss) > 1 {
|
2024-01-19 08:59:35 +00:00
|
|
|
|
dbParam = fmt.Sprintf("%s?schema=\"%s\"&escapeProcess=true", ss[0], ss[len(ss)-1])
|
2024-01-12 13:15:30 +08:00
|
|
|
|
} else {
|
2024-01-19 08:59:35 +00:00
|
|
|
|
dbParam = db + "?escapeProcess=true"
|
2024-01-12 13:15:30 +08:00
|
|
|
|
}
|
2024-01-19 08:59:35 +00:00
|
|
|
|
} else {
|
|
|
|
|
|
dbParam = "?escapeProcess=true"
|
2024-01-12 13:15:30 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
err := d.IfUseSshTunnelChangeIpPort()
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
|
return nil, err
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2024-01-19 08:59:35 +00:00
|
|
|
|
dsn := fmt.Sprintf("dm://%s:%s@%s:%d/%s", d.Username, url.PathEscape(d.Password), d.Host, d.Port, dbParam)
|
2024-01-12 13:15:30 +08:00
|
|
|
|
return sql.Open(driverName, dsn)
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
func (md *DmMeta) GetDialect(conn *dbi.DbConn) dbi.Dialect {
|
|
|
|
|
|
return &DMDialect{conn}
|
|
|
|
|
|
}
|