微信扫一扫打赏支持

thinkphp事务机制

thinkphp事务机制

一、总结

下面文章也要看,下面有抛出异常(自己提供错误信息那种)

1、事务机制(原子性):所有的事情都完成了就提交,否则回滚。电商里面用的多,付钱买东西的时候

2、样例(简单样例)开启事务,提交事务,删除事务,感觉下面的try-catch方式更专业

 // 开启事务

 1 Db::startTrans();
 2 
 3 
 4 
 5 // 删除数据 33
 6 
 7 $a=Db::table("user")->delete(33);
 8 
 9 // 删除数据 34
10 
11 $b=Db::table("user")->delete(34);
12 
13 
14 
15 // 判断条件
16 
17 if ($a && $b) {
18 
19          // 提交事务
20 
21          Db::commit();
22 
23 }else{
24 
25          // 回滚事务
26 
27          Db::rollback();
28 
29 }

 

 

 

二、thinkphp事务机制

 1、事务

 

                   张三 银行卡 1000, 李四 银行卡 500, 张三给李四转账200

 

                   1) 银行 先扣除 张三的200

 

                   2) 银行 将200 给了李四

 

 

         2、mysql事务

 

                   mysql事务 要求 数据库的引擎必须 InnoDB

 

 

         3、使用

 

                   1、自动控制事务

 

                            Db::transaction(function(){

 

                                     // 删除一条数据

 

                                     Db::table("user")->delete(40);

 

                                     // 删除数据

 

                                     Db::table("user")->deletes();

                            });

 

                   2、手动控制事务 (***)

 

                            // 开启事务

 

                            Db::startTrans();

 

                            // 事务

 

                            try{

                                     // 删除数据id 31

                                     $a=Db::table("user")->delete(31);

                                     // 判断是否删除成功

                                     if (!$a) {

                                               throw new \Exception("删除id 31 数据没有成功");

                                     }

                                     // 删除不存在的数据 id 32

                                     $b=Db::table("user")->delete(32);

                                     // 判断是否删除成功

                                     if (!$b) {

                                               throw new \Exception("删除id 32 数据没有成功");

                                     }

                                     // 执行提交操作

                                     Db::commit();

                            }catch(\Exception $e){

                                     // 回滚事务

                                     Db::rollback();

                                     // 获取提示信息

                                     dump($e->getMessage());

                            }

 

                   // ==================================================================

 

                            // 开启事务

                            Db::startTrans();

 

                            // 删除数据 33

                            $a=Db::table("user")->delete(33);

                            // 删除数据 34

                            $b=Db::table("user")->delete(34);

 

                            // 判断条件

                            if ($a && $b) {

                                     // 提交事务

                                     Db::commit();

                            }else{

                                     // 回滚事务

                                     Db::rollback();

                            }

 

posted @ 2018-05-09 23:08  范仁义  阅读(1302)  评论(0编辑  收藏  举报