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;