前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >学习gorm系列一:创建数据库连接

学习gorm系列一:创建数据库连接

作者头像
Go学堂
发布2023-08-29 16:51:03
4740
发布2023-08-29 16:51:03
举报
文章被收录于专栏:Go工具箱

大家好,我是渔夫子。

所以本系列文章意在深入的学习gorm,以便更好的理解和使用gorm,而不是简单的使用增、删、改、查功能。

什么是gorm

gorm是用于golang编程的非常优秀的ORM库,可使开发者对数据库使用更为方便。该库不仅支持多种数据库。而且还提供了查询构建器、关系映射、事务等多种功能。

初始化数据库连接:gorm.Open

要针对数据库进行操作,第一步就是要创建一个和数据库的连接。在gorm中使用的就是gorm.Open函数。接下来就们就看一下gorm.Open都做了些什么事儿。

假设我们要连接一个mysql数据库,像如下代码这样就能建立数据的连接:

代码语言:javascript
复制
import (
  "gorm.io/driver/mysql"
  "gorm.io/gorm"
)

func main() {
  // refer https://github.com/go-sql-driver/mysql#dsn-data-source-name for details
  dsn := "user:pass@tcp(127.0.0.1:3306)/dbname?charset=utf8mb4&parseTime=True&loc=Local"
  db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{})
}

我们看到上面的代码还依赖了mysql的驱动库:gorm.io/driver/mysql,该库是mysql的驱动库。这个就是要告诉gorm要连接的具体数据库了。在go-gorm项目下还能找到sqlitesqlserverpostgres以及clickhouse等常用的数据库的驱动库。地址是:https://github.com/go-gorm目录下。

我们再看下gorm.Open的函数原型:

代码语言:javascript
复制
func Open(dialector Dialector, opts ...Option) (db *DB, err error)

第一个参数是Dialector接口。该接口定义如下:

代码语言:javascript
复制
type Dialector interface {
 Name() string
 Initialize(*DB) error
 Migrator(db *DB) Migrator
 DataTypeOf(*schema.Field) string
 DefaultValueOf(*schema.Field) clause.Expression
 BindVarTo(writer clause.Writer, stmt *Statement, v interface{})
 QuoteTo(clause.Writer, string)
 Explain(sql string, vars ...interface{}) string
}

看到这里就明白了,只要具体的数据库驱动实现了该接口,gorm就能支持该数据库的连接。也就是说上面我们提到的go-gorm目录下的各种具体的数据库驱动都实现了Dialector接口。

image.png

dsn是什么

dsn,即data source name,指的是数据源名称。在golang中,其格式如下:

代码语言:javascript
复制
[user[:password]@][net[(addr)]]/dbname[?param1=value1&paramN=valueN]

mysql.Open函数

mysql.Open函数的返回值是gorm.Dialector对象。也就是说这里只是把相关的配置赋值给了gorm.Dialector接口类型,并没有实际的和数据库建立连接。如下是mysql.Open函数的实现:

代码语言:javascript
复制
func Open(dsn string) gorm.Dialector {
 dsnConf, _ := mysql.ParseDSN(dsn)
 return &Dialector{Config: &Config{DSN: dsn, DSNConfig: dsnConf}}
}

当然,其他数据库的Open函数也是类似,比如clickhouse数据库的Open函数实现如下:

代码语言:javascript
复制
func Open(dsn string) gorm.Dialector {
 return &Dialector{Config: &Config{DSN: dsn}}
}

建立数据库连接:Dialector.Initialize

在gorm.Open函数中,是通过Dialector.Initialize函数和数据库建立实际连接的。如下:

代码语言:javascript
复制
if config.Dialector != nil {
   err = config.Dialector.Initialize(db)
}

Dialector就是上文中提到的通过各个具体的数据库驱动的Open函数返回的接口类型。实际上也就是自己驱动下Dialector对象。然后在执行各自实例的Initialize函数,就能通过dsn中配置的地址和账号建立数据库连接了。

我们还是以mysql数据库为例,我们看下Initialize函数的核心实现:

本质上,在创建数据库连接的时候还是基于golang标准库的database/sql库实现的。最终,通过gorm.Open函数就初始化了一个数据库的连接

核心数据结构

上文提到,通过gorm.Open函数会得到一个gorm.DB对象。该对象是gorm中的核心数据结构。如下是gorm.DB的结构体:

在gorm.DB结构中主要包含两个类型的字段:Config和Statement。Config结构体根据名字可知主要是一些和数据库相关的配置,比如和账号密码以及连接地址相关的Dailector、数据库的连接ConnPool,日志相关的等。

Statement结构体,我们看到该结构体的主要由Table、Model、Select、Schema等组成,可想而知是跟具体的sql语句有关系的。

总结

通过gorm建立数据库连接的时候,要依赖于具体连接哪种数据库,所以gorm项目下提供了多种数据库的驱动。这些数据库驱动遵守gorm提供的接口类型Dailector来创建连接。实际创建连接的函数是Initialize函数,并将创建好的连接返回给gorm.DB.ConnPool字段中。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2023-08-24,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Go学堂 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 什么是gorm
  • 初始化数据库连接:gorm.Open
    • dsn是什么
      • mysql.Open函数
        • 建立数据库连接:Dialector.Initialize
          • 核心数据结构
          • 总结
          相关产品与服务
          数据库
          云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档