gorm踩的坑

gorm的那些坑

1. db.SingularTable(true)

在Gorm中,表名是结构体名的复数形式,列名是字段名的蛇形小写。即,如果有一个user表,那么如果你定义的结构体名为:User,gorm会默认表名为users而不是user。

db.SingularTable(true) 让grom转义struct名字的时候不用加上s

2. Rows.Next() 需要关闭

每次返回的rows 都是新的实例,占用一个数据库连接. rows.next()直到false 就会关闭,否则就会出现资源没有被回收,但数据库设置的超时回收也会去回收 但是会降低服务Tps。

user := new(User)
rows, err := engine.Where("id >?", 1).Rows(user)
if err != nil {
}
defer rows.Close()
for rows.Next() {
    err = rows.Scan(user)
} 

3. Scan error on column index 1, name “created_at”: unsupported Scan, storing driver.Value type []uint8

parseTime是查询结果是否自动解析为时间。+loc是MySQL的时区设置

parseTime=True&loc=Local

4. NewRecord和Create

db.NewRecord(user) // => 主键为空返回true
db.Create(&user)

NewRecord 检查主键是否存在
Create 即执行 insert 操作

  • 4
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值