关于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, // 使用单数表名
		},
	})

至此,问题解决

文章作者: sopp
版权声明: 本站所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 个人主页
golang golang gorm
喜欢就支持一下吧