Db事务的使用

1.首先try{ }catch(Exception $e){ }使用起来【异常捕捉】

try catch会将此处的一系列报错信息捕捉起来,不直接返回给浏览器,当他捕捉到错误之后,会进入catch中,若全程无错,则会直接跳过catch一直往下执行,所有我们对于想要捕捉错误但不返回给浏览器或者想要自定义报错的时候,就可以使用该语句。

2.开启事务 TP5是 Db::startTrans() laravel是DB::beginTransaction();

该事务实际就是数据库中的事务操作,beginTransaction是开启事务,rollback是回滚,commit是提交。 

(ps:若事务开启无效果,注意数据库表引擎是否是InnoDB的类型。myisam引擎类型是不支持事务的)


try{
    Db::startTrans()
    $data['id'] ='1'
    $data['name']='小明';
    $data['age'] = '7';
    $Students = new students();
   $addStatus = $Students->addStudents($data);
    if(!$addStatus)	throw new Exception('学生表添加数据失败') //抛出异常

    $addstudents['student_id']=$data['id'];
    $addstudents['student_name']='小明';
    $class = new class();
    $add_class= $class->addstudents($addstudents);
    if(!$addStatus)	throw new Exception('班级表添加数据失败') //抛出异常

}catch(Exception $e){
//在此处可捕捉错误信息,便于后期检查报错
    Log::info($e->getMessage());
    Db::rollback(); 
    return false;
}
    Db::commit;
    return true;

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值