一,创建一个order类,在其中应用事务
1,创建order的model
~~~
liuhongdi@lhdpc:/data/php/admapi$ php think make:model Order
Model:app\model\Order created successfully.
~~~
2,代码:
model/Order.php
[![复制代码](https://common.cnblogs.com/images/copycode.gif)](javascript:void(0); "复制代码")
~~~
<?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://common.cnblogs.com/images/copycode.gif)](javascript:void(0); "复制代码")
说明:刘宏缔的架构森林是一个专注架构的博客,地址:[https://www.cnblogs.com/architectforest](https://www.cnblogs.com/architectforest)
对应的源码可以访问这里获取: [https://github.com/liuhongdi/](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,代码
[![复制代码](https://common.cnblogs.com/images/copycode.gif)](javascript:void(0); "复制代码")
~~~
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,"报错");
}
}
}
~~~
[![复制代码](https://common.cnblogs.com/images/copycode.gif)](javascript:void(0); "复制代码")
## 三,测试效果:
1,成功:
查看order表:
![](https://img.kancloud.cn/0c/e6/0ce6329f7926adef5cd25e352012a8fd_842x291.png)
查看goods表:
![](https://img.kancloud.cn/2f/d2/2fd2df32fe63bf2a39e159cff30698b2_842x284.png)
访问:
~~~
http://127.0.0.1:8000/order/addorder
~~~
返回:
![](https://img.kancloud.cn/99/fb/99fb6ec31eef7bdcb490c669e5a74827_422x187.png)
查看增加的数据:
![](https://img.kancloud.cn/93/ce/93ce32b68695885dfff48aa799cf5f66_843x360.png)
![](https://img.kancloud.cn/bf/1a/bf1ad9f0ed47effe3438476ddd5ee071_843x310.png)
2,失败:
此处需要model/Order.php中的
~~~
//$z = 0;
//$a = 100 / $z;
~~~
此两行代码取消注释,生成一个除0错:
访问:
~~~
http://127.0.0.1:8000/order/addorder
~~~
返回:
![](https://img.kancloud.cn/fa/89/fa8966507ba71fe194744d69c6d35e5f_389x185.png)
查看数据库:
可以看到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
~~~
- thinkphp6执行流程(一)
- php中use关键字用法详解
- Thinkphp6使用腾讯云发送短信步骤
- 路由配置
- Thinkphp6,static静态资源访问路径问题
- ThinkPHP6.0+ 使用Redis 原始用法
- smarty在thinkphp6.0中的最佳实践
- Thinkphp6.0 搜索器使用方法
- 从已有安装包(vendor)恢复 composer.json
- tp6with的用法,表间关联查询
- thinkphp6.x多对多如何添加中间表限制条件
- thinkphp6 安装JWT
- 缓存类型
- 请求信息和HTTP头信息
- 模型事件用法
- 助手函数汇总
- tp6集成Alipay 手机和电脑端支付的方法
- thinkphp6使用jwt
- 6.0session cookie cache
- tp6笔记
- TP6(thinkphp6)队列与延时队列
- thinkphp6 command(自定义指令)
- command(自定义指令)
- 本地文件上传
- 缓存
- 响应
- 公共函数配置
- 七牛云+文件上传
- thinkphp6:访问多个redis数据源(thinkphp6.0.5 / php 7.4.9)
- 富文本编辑器wangEditor3
- IP黑名单
- 增删改查 +文件上传
- workerman 定时器操作控制器的方法
- 上传文件到阿里云oss
- 短信或者邮箱验证码防刷代码
- thinkphp6:访问redis6(thinkphp 6.0.9/php 8.0.14)
- 实现关联多个id以逗号分开查询数据
- thinkphp6实现邮箱注册功能的细节和代码(点击链接激活方式)
- 用mpdf生成pdf文件(php 8.1.1 / thinkphp v6.0.10LTS )
- 生成带logo的二维码(php 8.1.1 / thinkphp v6.0.10LTS )
- mysql数据库使用事务(php 8.1.1 / thinkphp v6.0.10LTS)
- 一,创建过滤IP的中间件
- 源码解析请求流程
- 验证码生成
- 权限管理
- 自定义异常类
- 事件监听event-listene
- 安装与使用think-addons
- 事件与多应用
- Workerman 基本使用
- 查询用户列表按拼音字母排序
- 扩展包合集
- 查询用户数据,但是可以通过输入用户昵称来搜索用户同时还要统计用户的文章和粉丝数
- 根据图片的minetype类型获取文件真实拓展名思路
- 到处excel
- 用imagemagick库生成缩略图
- 生成zip压缩包并下载
- API 多版本控制
- 用redis+lua做限流(php 8.1.1 / thinkphp v6.0.10LTS )
- 【thinkphp6源码分析三】 APP类之父, 容器Container类
- thinkphp6表单重复提交解决办法
- 小程序授权
- 最简单的thinkphp6导出Excel
- 根据访问设备不同访问不同模块
- 服务系统
- 前置/后置中间件
- 给接口api做签名验证(php 8.1.1 / thinkphp v6.0.10LTS )
- 6实现邮箱注册功能的细节和代码(点击链接激活方式)
- 使用前后端分离的验证码(thinkphp 6.0.9/php 8.0.14/vue 3.2.26)
- 前后端分离:用jwt+middleware做用户登录验证(php 8.1.1 / thinkphp v6.0.10LTS )
- vue前后端分离多图上传
- thinkphp 分组、页面跳转与ajax
- thinkphp6 常用方法文档
- 手册里没有的一些用法
- Swagger 3 API 注释
- PHP 秒级定时任务
- thinkphp6集成gatewayWorker(workerman)实现实时监听
- thinkphp6按月新增数据表
- 使用redis 实现消息队列
- api接口 统一结果返回处理类
- 使用swoole+thinkphp6.0+redis 结合开发的登录模块
- 给接口api做签名验证
- ThinkPHP6.0 + UniApp 实现小程序的 微信登录
- ThinkPHP6.0 + Vue + ElementUI + axios 的环境安装到实现 CURD 操作!
- 异常$e
- 参数请求验证自定义和异常错误自定义