golang panic: runtime error: invalid memory address or nil pointer dereference [

前端之家收集整理的这篇文章主要介绍了golang panic: runtime error: invalid memory address or nil pointer dereference [前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

今天做消息队列持久化存储服务过程中,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("更新成功")
}
}

执行成功

猜你在找的Go相关文章