关于golang的orm框架gorm的踩坑记录
今天在研究使用gorm框架的时候,发现一个坑,在官方文档中并没有指名这个坑,现在记录一下。
1. 表名后缀自动带上 s
的解决办法
在使用gorm的时候,首先都是获取数据库连接,例如:
import (
"gorm.io/driver/mysql"
"gorm.io/gorm"
)
func main() {
// 参考 https://github.com/go-sql-driver/mysql#dsn-data-source-name 获取详情
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{})
}
上述代码,看起来没有任何问题,但是实际上,在进行单表的操作的时候,会报错,说表不存在,比如,你操作的是 user
表,但是实际上,gorm默认配置使用双数表名,也就是会给你自动加上 s
结尾,导致你的操作的表,就是带 s
后缀的,那么肯定就是错误的了!
解决办法: 新增gorm.config,在里面配置使用单数表名~
var err error
db, err = gorm.Open(mysql.New(mysql.Config{
DSN: "root:root@tcp(localhost:3307)/test?charset=utf8&parseTime=True&loc=Local", // DSN data source name
DefaultStringSize: 256, // string 类型字段的默认长度
DisableDatetimePrecision: true, // 禁用 datetime 精度,MySQL 5.6 之前的数据库不支持
DontSupportRenameIndex: true, // 重命名索引时采用删除并新建的方式,MySQL 5.7 之前的数据库和 MariaDB 不支持重命名索引
DontSupportRenameColumn: true, // 用 `change` 重命名列,MySQL 8 之前的数据库和 MariaDB 不支持重命名列
SkipInitializeWithVersion: false, // 根据当前 MySQL 版本自动配置
}), &gorm.Config{
NamingStrategy: schema.NamingStrategy{
SingularTable: true, // 使用单数表名
},
})
至此,问题解决