laravel 事务

表必须是InnoDB引擎

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

DB::beginTransaction();

try{

    $name 'abc';

    $result1 = Test::create(['name'=>$name]);

    if (!$result1) {

        /**

         * Exception类接收的参数

         * $message = "", $code = 0, Exception $previous = null

         */

        throw new \Exception("1");

    }

    $result2 = Test::create(['name'=>$name]);

    if (!$result2) {

        throw new \Exception("2");

    }

    DB::commit();

catch (\Exception $e){

    DB::rollback();//事务回滚

    echo $e->getMessage();

    echo $e->getCode();

}

  注意:如果id是自增的话,mysql的primary key是在内存中维护的,事务回滚是不会回退id,所以中间会出现断层

转载于:https://my.oschina.net/guozhouyuan/blog/1975560

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值