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