【golang】运行golang链接mysql出现invalid memory address or nil pointer dereference错误

285 阅读1分钟

编写不易,还希望各位大佬支持一下\textcolor{gray}{编写不易,还希望各位大佬支持一下}
📃 个人主页:\textcolor{green}{个人主页:} 沉默小管
📃 个人网站:\textcolor{green}{个人网站:} 沉默小管
🔥 技术交流QQ群:837051545\textcolor{green}{技术交流QQ群:837051545}
👍 点赞,你的认可是我创作的动力!\textcolor{green}{点赞,你的认可是我创作的动力!}
⭐️ 收藏,你的青睐是我努力的方向!\textcolor{green}{收藏,你的青睐是我努力的方向!}
✏️ 评论,你的意见是我进步的财富!\textcolor{green}{评论,你的意见是我进步的财富!}
如果有不懂可以留言,我看到了应该会回复 如有错误,请多多指教

问题描述:

golang使用xorm链接数据库,后进行查询时报出invalid memory address or nil pointer dereference

问题原因:

import (
"xorm.io/xorm"
)

var engine *xorm.Engine

func ConnDB() *xorm.Engine {
    return engine
}
//初始化,自动运行
func init() {
    engine, err := xorm.NewEngine(...xxx)
    ...xxx
}

在init函数中使用:=定义,该定义是局部定义的临时变量,外部var engine *xorm.Engine又定义了一个全局定义,所以这里的全局定义是无效的 所以,调用ConnDB函数,返回的engine是为空

解决流程:

把:去掉,engine的初始化变量为全局

engine, err = xorm.NewEngine(...xxx)