thinkphp6:mysql数据库使用事务(php 8.1.1 / thinkphp v6.0.10LTS)
2023-09-14 08:59:32 时间
一,创建一个order类,在其中应用事务
1,创建order的model
liuhongdi@lhdpc:/data/php/admapi$ php think make:model Order Model:app\model\Order created successfully.
2,代码:
model/Order.php
<?php declare (strict_types = 1); namespace app\model; use think\Exception; use think\facade\Db; use think\Model; /** * @mixin \think\Model */ class Order extends Model { //类名与表名不一致时在这里指定数据表名 protected $table = "orderInfo"; public function addOrderAndGoods($orderRow,$goodsRows) { //启动事务 Db::startTrans(); try { $result = Db::table("orderInfo")->insert($orderRow); if(!$result){ throw new Exception("insert order失败"); } //得到orderid $orderId = Db::table('orderInfo')->getLastInsID();; //$z = 0; //$a = 100 / $z; foreach ($goodsRows as $k => $row){ $row['orderId'] = $orderId; $result = Db::table("orderGoods")->insert($row); if(!$result){ throw new Exception("insert goods失败"); } } // 提交事务 Db::commit(); //} catch (Exception $e){ } catch (\Throwable $e){ // 事务回滚 Db::rollback(); return false; } return true; } }
说明:刘宏缔的架构森林是一个专注架构的博客,地址:https://www.cnblogs.com/architectforest
对应的源码可以访问这里获取: https://github.com/liuhongdi/
说明:作者:刘宏缔 邮箱: 371125307@qq.com
二,controller/Order.php
1,创建controller
liuhongdi@lhdpc:/data/php/admapi$ php think make:controller Order Controller:app\controller\Order created successfully.
2,代码
class Order extends BaseController { /* 创建订单 */ public function addOrder() { $orderRow = [ "orderStatus"=>0, "addTime"=>date("Y-m-d H:i:s"), "price"=>"10.5", "subject"=>"订单:".date("YmdHis")."_".rand(100,999), ]; $goodsRows = [ [ "goodsId"=>15, "goodsName"=>"洽洽瓜子新年1装".date("YmdHis")."_".rand(100,999), ], ]; $order = new OrderModel(); $isSucc = $order->addOrderAndGoods($orderRow,$goodsRows); if ($isSucc){ return Result::Success("成功"); } else { return Result::Error(1,"报错"); } } }
三,测试效果:
1,成功:
查看order表:
查看goods表:
访问:
http://127.0.0.1:8000/order/addorder
返回:
查看增加的数据:
2,失败:
此处需要model/Order.php中的
//$z = 0; //$a = 100 / $z;
此两行代码取消注释,生成一个除0错:
访问:
http://127.0.0.1:8000/order/addorder
返回:
查看数据库:
可以看到order表和goods中的数据都没有增加
注意观察,可以发现order表中的自增id会增长,
是因为在添加数据后事务中出现异常时进行了回滚
四,查看php和thinkphp的版本:
php:
liuhongdi@lhdpc:/data/php/admapi$ php --version PHP 8.1.1 (cli) (built: Dec 20 2021 16:12:16) (NTS) Copyright (c) The PHP Group Zend Engine v4.1.1, Copyright (c) Zend Technologies with Zend OPcache v8.1.1, Copyright (c), by Zend Technologies
thinkphp:
liuhongdi@lhdpc:/var/www/html$ cd /data/php/admapi/ liuhongdi@lhdpc:/data/php/admapi$ php think version v6.0.10LTS
相关文章
- MySQL数据库丢失:挣扎寻找中(找不到mysql数据库)
- MySQL官方网站:不可错过的开源数据库解决方案(mysql官网)
- Mysql查看定时任务:探索科学计划之路(mysql查看计划任务)
- 安全MySQL数据库账号安全保障措施(mysql数据库账号)
- MySQL数据库应用: 驱动包开启新体验(mysql数据库驱动包)
- 深入理解MySQL转义在PHP中的应用技巧(mysql转义php)
- MySQL计划任务实现定期备份(mysql计划任务备份)
- MySql手册:轻松下载体验(mysql手册下载)
- 最佳架构:MySQL环境优化实战(mysql环境要求)
- 悔不当初:如何恢复误删MySQL数据库(误删mysql数据库)
- MySQL语句大全:25种常用语句完全解读(常用的mysql语句)
- 怎么办? How to Deal with a Stuck MySQL Database?(mysql数据库卡)
- MySQL数据库:高级应用技巧教程(mysql数据库高级教程)
- MySQL中如何查询表格(mysql中查询表)
- 深入了解MySQL中的PSB优化你的数据库管理技能(mysql中psb)
- 将CSV数据迁移至MySQL数据库(csv转到mysql)
- 射手呼唤MySQL展开不一样的数据之旅(archer mysql)
- 用户名妙用CMD命令给MySQL设定用户名(cmd命令设置mysql)
- 数据库备份Cmd下MySQL数据库备份简单而快速的方式(cmd命令下mysql)
- MySQL实现一列多值存储方法(mysql一列多值)
- MySQL 状态监控了解数据库性能的关键(mysql_status)
- MySQL学习使用 mysqlclose 函数关闭数据库连接(mysql_close6)
- MySQL数据库的两个重要方向(mysql 两点 方向)