加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

golang panic: runtime error: invalid memory address or nil p

发布时间:2020-12-16 18:27:29 所属栏目:大数据 来源:网络整理
导读:今天做消息队列持久化存储服务过程中,golang操作mysql 报错: panic : runtime error invalid memory address or nil pointer dereference [ 经过反复查找,原来是变量定义问题 做个记录,以后再有问题可以做个参考,原始代码: varDb*sql.DBfuncinit(){Db,

今天做消息队列持久化存储服务过程中,golang操作mysql 报错:

panic:runtime errorinvalid memory address or nil pointer dereference[

经过反复查找,原来是变量定义问题 做个记录,以后再有问题可以做个参考,原始代码:

varDb*sql.DB

funcinit(){
Db,err:=sql.Open("mysql","root:123456@/test")
iferr!=nil{
panic(err)
}
}
/**
*记录访问日志
*/
func(cCommonlog)saveViewlog(){
SqlIn:=fmt.Sprintf("insertintoq_orgviewlog(viewnum,orgid,statisticsdate)values(1,%d,%d)",c.Orgid,time.Now().Unix())
_,err:=Db.Exec(SqlIn)

iferr!=nil{
fmt.Println("用户SQL错误,执行时间:",time.Now().String(),"错误内容:",err.Error(),"SQL:",sqlUpdate)
fmt.Println(err)
}else{
fmt.Println("更新成功")
}
}


然后就报了上面的错误


经过反复查询,Db变量定义的问题,:=只在当前方法内有效,于是修改如下:

varDb*sql.DB

funcinit(){
varerrerror
Db,err=sql.Open("mysql",sqlUpdate)
fmt.Println(err)
}else{
fmt.Println("更新成功")
}
}

执行成功

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读