web开发基本都离不开访问数据库,在Gin中使用mysql数据库需要依赖mysql的驱动。直接使用驱动提供的API就要写很多样板代码。你可以找到很多扩展包这里介绍的是jmoiron/sqlx。另外还有一个用来处理空值的包guregu/null。
1 | go get github.com/go-sql-driver/mysql |
连接数据库
jmoiron/sqlx包为database/sql提供了很多扩展方法,例如Select可以直接把查询结果映射为结构体,不在需要对每一列进行绑定。使用jmoiron/sqlx连接数据库的方法和mysql驱动提供的方法是一样的,可以直接调用sqlx.Connect并传入连接字符串。这里使用go语言init机制初始化数据库连接。
1 | package db |
连接字符串中设置parseTime=true是为了解析mysql中日期时间类型。
1 | type SysRole struct { |
在go语言中int、string之类的类型是不可以为空的,sql.NullXXX类型代表了数据库中的可空类型。还要注意一下CreateTime字段的标签,如果表的列名和结构体字段名不一样的话就要添加db标签db:"create_time"。
访问一下接口你会发现结果可能并不是你想要的,每一个可空类型的字段都变成了对象。
1 | { |
解决空值的问题
使用guregu/null包可以解决空值的问题,guregu/null为数据库和JSON提供了可空的数据类型,可以替换掉所有sql.NullXXX类型。更新后的结构体如下:
1 | type SysRole struct { |
再次访问接口会看到熟悉的JSON结果,并且当数据为空时也能返回正确的值。
1 | { |