mirror of
https://gitee.com/dromara/mayfly-go
synced 2025-11-03 16:00:25 +08:00
* fix: 代码合并 * feat:支持数据库版本兼容,目前兼容了oracle11g部分特性 * fix: 修改数据同步bug,数据sql里指定修改字段别,导致未正确记录修改字段值 * feat: 数据库迁移支持定时迁移和迁移到sql文件
39 lines
903 B
Go
39 lines
903 B
Go
package sqlite
|
||
|
||
import (
|
||
"database/sql"
|
||
"errors"
|
||
"mayfly-go/internal/db/dbm/dbi"
|
||
"os"
|
||
)
|
||
|
||
func init() {
|
||
dbi.Register(dbi.DbTypeSqlite, new(Meta))
|
||
}
|
||
|
||
type Meta struct {
|
||
}
|
||
|
||
func (md *Meta) GetSqlDb(d *dbi.DbInfo) (*sql.DB, error) {
|
||
// 用host字段来存sqlite的文件路径
|
||
// 检查文件是否存在,否则报错,基于sqlite会自动创建文件,为了服务器文件安全,所以先确定文件存在再连接,不自动创建
|
||
if _, err := os.Stat(d.Host); err != nil {
|
||
return nil, errors.New("数据库文件不存在")
|
||
}
|
||
|
||
db, err := sql.Open("sqlite", d.Host)
|
||
if err != nil {
|
||
return nil, err
|
||
}
|
||
_, err = db.Exec("PRAGMA busy_timeout = 50000;")
|
||
return db, err
|
||
}
|
||
|
||
func (sm *Meta) GetDialect(conn *dbi.DbConn) dbi.Dialect {
|
||
return &SqliteDialect{dc: conn}
|
||
}
|
||
|
||
func (sm *Meta) GetMetaData(conn *dbi.DbConn) *dbi.MetaDataX {
|
||
return dbi.NewMetaDataX(&SqliteMetaData{dc: conn})
|
||
}
|