一,創建一個order類,在其中應用事務
1,創建order的model
~~~
liuhongdi@lhdpc:/data/php/admapi$ php think make:model Order
Model:app\model\Order created successfully.
~~~
2,代碼:
model/Order.php
[](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;
}
}
~~~
[](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,代碼
[](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,"報錯");
}
}
}
~~~
[](javascript:void(0); "復制代碼")
## 三,測試效果:
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
~~~
- 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
- 參數請求驗證自定義和異常錯誤自定義