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

1986410806 · 2023-06-13 18:46:04 · 2635 次点击 · 预计阅读时间 1 分钟 · 大约8小时之前 开始浏览    
这是一个创建于 2023-06-13 18:46:04 的文章,其中的信息可能已经有所发展或是发生改变。

一切都源于我开发中发现的一个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

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