求助一个问题,关于协程和gorm的

1986410806 · · 2400 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

### 一切都源于我开发中发现的一个bug,简单描述就是 先insert 了一条数据,然后开启了一个协程,直接进行查询刚才插入的数据,竟然没查到。 > 代码如下 ``` func Test(t *testing.T) { record := &model.ContentCoursePracticeRecord{ Cid: 0, Uid: 1, Complete: 1, Type: 2, Duration: 100, Ctime: time.Now(), Uptime: time.Now(), } err := dao.ContentCoursePracticeRecordDao.Create(record) assert.Equal(t, err, nil) go func() { // 查询0元购活动 var ( duration int ) db, err := utils.GetDB() if err != nil { assert.Equal(t, err, nil) } if ret := db.Model(&model.ContentCoursePracticeRecord{}). Where("isdel = 0 and uid = ?", 1). Where("ctime >= ?", time.Now().Format("2006-01-02")). Select("sum(duration) as duration"). Find(&duration); ret.Error != nil { // 此处报错 ,说明没有数据 //sql: Scan error on column index 0, name "duration": converting NULL to int is unsupported assert.Equal(t, err, nil) } }() } ``` 他不是一个必现的问题,我也没有成功复现出来 后来把查询从写成挪出去就没有问题了,但是也没有想明白问题?望各位大佬指点!

有疑问加站长微信联系(非本文作者))

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

2400 次点击  
加入收藏 微博
9 回复  |  直到 2023-06-16 09:51:34
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传