Golang - 访问数据库报错后程序继续运行

学习笔记 专栏收录该内容
14 篇文章 0 订阅

 

1、问题缘由

在学习golang的时候,发现panic挺好用,但是有一个问题,比如执行update数据库,会报错faminly字段不存在,然后golang主程序直接退出了,没有找到类似try catch exception的方式,让我不得其解。后来网上请教golang高手,得知问题出在这里:Golang处理异常是用error返回的方式,然后调用方根据error的值走不同的处理逻辑。但是,如果程序触发其他的严重异常,比如说数组越界,程序就要直接崩溃。关于这种问题,可以考虑使用defer、panic、recover联合使用来解决

 

2、关于Defer、Panic、Recover


Defer
Defer语句将一个函数放入一个列表(用栈表示其实更准确)中,该列表的函数在环绕defer的函数返回时会被执行。defer通常用于简化函数的各种各样清理动作,例如关闭文件,解锁等等的释放资源的动作。
Panic
Panic是内建的停止控制流的函数。相当于其他编程语言的抛异常操作。当函数F调用了panic,F的执行会被停止,在F中panic前面定义的defer操作都会被执行,然后F函数返回。对于调用者来说,调用F的行为就像调用panic(如果F函数内部没有把panic recover掉)。如果都没有捕获该panic,相当于一层层panic,程序将会crash。panic可以直接调用,也可以是程序运行时错误导致,例如数组越界。

Recover
Recover是一个从panic恢复的内建函数。Recover只有在defer的函数里面才能发挥真正的作用。如果是正常的情况(没有发生panic),调用recover将会返回nil并且没有任何影响。如果当前的goroutine panic了,recover的调用将会捕获到panic的值,并且恢复正常执行。

 

3、问题解决

一个专门处理异常错误的方法:
func check_eorr(err error,exesql string){
   defer func() {

      if r := recover(); r != nil {
         fmt.Printf("get error infomation:%s\n", r)
      }
   }()

   if err != nil {
      fmt.Println("query or exec error:",exesql)
      panic(err)

   }
}

 

使用的时候这样用:

func insert_data(){
   age:=20
   exesql:="SELECT name FROM users WHERE age= '"+age+"'"
   rows, err := db.Query(exesql)
   // 调用错误处理方法check_error
   check_eorr(err,exesql)
}

 

  • 1
    点赞
  • 2
    评论
  • 1
    收藏
  • 打赏
    打赏
  • 扫一扫,分享海报

评论 2 您还未登录,请先 登录 后发表或查看评论
©️2022 CSDN 皮肤主题:大白 设计师:CSDN官方博客 返回首页

打赏作者

五茅

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值