为了将数据库驱动与框架主库解耦,从v2.1
版本开始,所有的数据库驱动都需要通过社区包手动引入。
数据库驱动的安装和引入请参考:https://github.com/gogf/gf/tree/master/contrib/drivers
GoFrame
框架的ORM
功能由gdb
模块实现,用于常用关系型数据库的ORM
操作。
|
注意:为提高数据库操作安全性,在 |
接口文档:
https://pkg.go.dev/github.com/gogf/gf/v2/database/gdb
GoFrame ORM
组件具有以下显著特点:
OpenTelemetry
可观测性:链路跟踪、日志记录、指标上报。Scan
方法自动识别Map/Struct
接收查询结果,自动化查询结果初始化、结构体类型转换。nil
识别为空,无需sql.ErrNoRows
识别查询数据为空的情况。Map/Struct/Slice
参数类型中的字段识别、过滤,大大提高查询条件输入、结果接收。GoFrame
框架层面的DAO
设计,全自动化Model/DAO
代码生成,极大提高开发效率。DryRun
、自定义Handler
、自动类型类型转换、自定义接口转换等等高级特性。GoFrame ORM Features
GoFrame ORM Dependencies
g.DB
与gdb.New
、gdb.Instance
获取数据库操作对象有三种方式,一种是使用g.DB
方法(推荐),一种是使用原生gdb.New
方法,还有一种是使用包原生单例方法gdb.Instance
,而第一种是推荐的使用方式。这三种方式的区别如下:
g.DB
对象管理方式获取的是单例对象,整合了配置文件的管理功能,支持配置文件热更新。gdb.New
是根据给定的数据库节点配置创建一个新的数据库对象(非单例),无法使用配置文件。gdb.Instance
是包原生单例管理方法,需要结合配置方法一起使用,通过分组名称(非必需)获取对应配置的数据库单例对象。有这么多对象获取方式原因在于 |
New
创建数据库对象db, err := gdb.New(gdb.ConfigNode{ Link: "mysql:root:12345678@tcp(127.0.0.1:3306)/test", }) |
// 获取默认配置的数据库对象(配置名称为"default") db := g.DB() // 获取配置分组名称为"user"的数据库对象 db := g.DB("user") // 使用原生单例管理方法获取数据库对象单例 db, err := gdb.Instance() db, err := gdb.Instance("user") |