Files
mayfly-go/server/internal/db/dbm/mysql/meta.go

49 lines
1.2 KiB
Go
Raw Normal View History

package mysql
import (
"context"
"database/sql"
"fmt"
"mayfly-go/internal/db/dbm/dbi"
"net"
"github.com/go-sql-driver/mysql"
)
func init() {
meta := new(Meta)
dbi.Register(dbi.DbTypeMysql, meta)
dbi.Register(dbi.DbTypeMariadb, meta)
}
type Meta struct {
}
func (mm *Meta) GetSqlDb(d *dbi.DbInfo) (*sql.DB, error) {
// SSH Conect
if d.SshTunnelMachineId > 0 {
2024-01-13 13:38:53 +08:00
sshTunnelMachine, err := dbi.GetSshTunnel(d.SshTunnelMachineId)
if err != nil {
return nil, err
}
mysql.RegisterDialContext(d.Network, func(ctx context.Context, addr string) (net.Conn, error) {
return sshTunnelMachine.GetDialConn("tcp", addr)
})
}
// 设置dataSourceName -> 更多参数参考https://github.com/go-sql-driver/mysql#dsn-data-source-name
dsn := fmt.Sprintf("%s:%s@%s(%s:%d)/%s?timeout=8s", d.Username, d.Password, d.Network, d.Host, d.Port, d.Database)
if d.Params != "" {
dsn = fmt.Sprintf("%s&%s", dsn, d.Params)
}
const driverName = "mysql"
return sql.Open(driverName, dsn)
}
func (mm *Meta) GetDialect(conn *dbi.DbConn) dbi.Dialect {
2024-03-15 13:31:53 +08:00
return &MysqlDialect{dc: conn}
}
func (mm *Meta) GetMetaData(conn *dbi.DbConn) *dbi.MetaDataX {
2024-03-15 13:31:53 +08:00
return dbi.NewMetaDataX(&MysqlMetaData{dc: conn})
}