## TP5實戰開發---模型技巧
在MVC模式下 model 的靈活應用可以減少代碼量,邏輯處理也更加清晰明確
下面 我拿一個商城的訂單Model實例來簡單介紹TP5的模型 (model)的用法
~~~
<?php
/**
* Created by PhpStorm.
* User: Mikkle
* Email:776329498@qq.com
* Date: 2017/1/4
* Time: 17:00
*/
namespace app\base\model;
use think\Db;
use think\Model;
class Orders extends Base
{
protected $table = "my_orders";
protected $name = "orders";
protected $pk = "id";
protected $insert = ['status'=>1,'guid','order_no','order_state'=>0,'pay_type'=>0,'send_state'=>0,'is_comment'=>0,'factory_state'=>0];
protected $autoWriteTimestamp = true;
}
~~~
先看一下前一部分
>[info] protected $table = "my_orders"; //表名
> protected $name = "orders";
> protected $pk = "id";
> protected $insert = ['status'=>1,'guid','order_no','order_state'=>0,'pay_type'=>0,'send_state'=>0,'is_comment'=>0,'factory_state'=>0];
> protected $autoWriteTimestamp = true; //開啟時間戳
其中這一部分主要說的是 自動完成 protected $insert
在這部分中后面定義了一個數組,其中有一部分已經定義值 而未賦值將自動調用修改器完成。
### Model中的獲取器和修改器
>[info] 詳情參見 我這里只講實例
> 獲取器 http://www.hmoore.net/manual/thinkphp5/135192
> 修改器 http://www.hmoore.net/manual/thinkphp5/135193
在這個訂單表中 使用獲取器
~~~
/**
* 獲取器
* Power by Mikkle
* QQ:776329498
* @param $value
* @param $data
* @return mixed
*/
public function getDistributeAttr($value, $data){
$get_data = ['SF'=>'順豐快遞','ZT'=>'中通快遞'];
return $get_data[$value];
}
public function getPayTimeAttr($value, $data){
return date('Y-m-d h:i:s', $value);
}
public function getPayTypeAttr($value, $data){
if ($value){
$get_data = ['WxPay'=>'微信支付','AliPay'=>'支付寶支付'];
return isset($get_data[$value]) ? $get_data[$value] : '其他方式';
}else{
return $value;
}
}
public function getIsPayTextAttr($value, $data){
$get_data = ['0'=>'未付款','1'=>'已付款'];
return $get_data[$data['is_pay']];
}
~~~
這幾個獲取器都比較簡單,都是常用數據轉換。
* * * * *
下面的源碼是修改器
~~~
protected function setGuidAttr($value, $data)
{
return $this->create_uuid() ;
}
/**
* 訂單類修改器 含防重復篩查
* Power by Mikkle
* QQ:776329498
* @param $value
* @param $data
* @return string
*/
protected function setOrderNoAttr($value, $data)
{
do {
$order_no= date('Ymd').$this->builderRand();
} while ($this->where('order_no',$order_no)->count()==1);
return $order_no ;
}
~~~
其中 setGuidAttr 使用model基類的create_uuid方法創造guid,而setOrderNoAttr是生產不重復的訂單號,生成方法依然使用了基類的方法。這里使用 do while循環進行了一次唯一性過濾(當數值存在,重新獲取)
>[danger] 需要注意的是,為了防止訂單號的重復,這里使用一次查庫過濾,雖然重復的幾率低,但是這種類型的值進行一次查庫還是有必要的。
* * * * *
下面這個例子是是分頁搜索的list列表,這里附加了字段不存在的cover_info的獲取器,
~~~
/**
* 獲取訂單列表 含append用法
* Power by Mikkle
* QQ:776329498
* @param array $map
* @param string $order
* @param int $limit
* @param int $page
* @return array
*/
public function getOrderList($map=[],$order = 'id desc',$limit=8,$page=1){
$field='order_no,order_num,amount,distribute,create_time,is_pay,send_state,order_state';
$map['status']=1;
$data=$this->where($map)->field($field)
->limit($limit)
->page($page)
->order($order)->select();
$re=[];
foreach($data as $order){
$re[]= $order->append(['cover_info'])->toArray();
}
return $re;
}
~~~
>[danger] 注意:模型中使用select返回的是多個對象的數組,對象中的獲取器只有在單個對象toArray才會全部生效,
$re=[];
foreach($data as $order){
$re[]= $order->append(['cover_info'])->toArray();
}
return $re;
所以在這個獲取器最后加入foreach循環
* * * * *
下面這個例子是訂單詳情
~~~
/**
* 訂單詳情
* Power by Mikkle
* QQ:776329498
* @param array $map
* @return array|bool|false|\PDOStatement|string|Model
*/
public function getOrderInfo($map=[]){
if (!$map) return false;
$field = 'order_no,amount,distribute,order_desc,consignee_name,consignee_mobile,consignee_address,send_state,is_pay,is_comment,order_state,create_time';
$data=$this->where($map)->field($field)->find();
if (!$data) return false;
//$data['cart_list']=$data->hasManyThrough('VGuidAll','OrdersAccess','order_no','my_guid','order_no')->select();
$data['cart_list']=$this->getOrderAccessList($data['order_no']);
return $data;
}
/**
* 訂單簡要信息
* Power by Mikkle
* QQ:776329498
* @param $order_no
* @return array|bool|false|\PDOStatement|string|Model
*/
public function getOrderSimpleInfo($order_no){
if (!$order_no) return false;
$map['order_no']=$order_no;
$field = 'order_no,amount,distribute,order_desc,consignee_name,consignee_mobile,consignee_address,create_time';
$data=$this->where($map)->field($field)->find();
if (!$data) return false;
return $data;
}
/*
* 關聯
*/
public function orderAccess(){
$this->hasMany('OrdersAccess','order_no','order_no');
}
/**
* 視圖查詢
* Power by Mikkle
* QQ:776329498
* @param $order_no
* @return false|\PDOStatement|string|\think\Collection
*/
public function getOrderAccessList($order_no){
return Db::view('my_orders_access','id,order_no,my_guid,my_num,my_price,is_comment')
->view('my_guid_all','my_name,my_type,my_price,my_pic','my_orders_access.my_guid=my_guid_all.my_guid')
->view('my_common_picture','path','my_common_picture.id=my_guid_all.my_pic')
->where('order_no',$order_no)
->cache('OrderList_'.$order_no)
->select();
}
~~~
>[danger] 在getOrderInfo方法中,比較復雜在初期寫的時候使用了關聯,后期修改會使用單獨的方法getOrderAccessList
> $data['cart_list']=$this->getOrderAccessList($data['order_no']);
> 在方法getOrderAccessList中使用了視圖view的方法,還使用了緩存(訂單商品列表是禁止修改的,所以這里為了加快查詢速度使用了緩存)
> PS:其實實現的方法很多,商品詳情列表使用獲取器也是可以完成的,大家也可以想一下。
* * * * *
下面這個實例是Model的數據庫的關聯和事務操作
~~~
try{
$this->startTrans();
$this->data($order_data)->isUpdate(false)->save();
$new_order = $this->order_no;
if (!is_numeric($new_order)) throw new \Exception("商品訂單添加失敗");
$this->hasMany('OrdersAccess', 'order_no', 'order_no')->saveAll($data_order);
$this->commit();
return ['code' => '1001', 'msg' => '商品訂單添加成功', 'data' => ['order_no' => $new_order, 'cart_list' => $data_order]];
}catch (\Exception $e){
$this->rollback();
return ['code'=>'1008','msg'=>'商品訂單添加失敗','data'];
}
~~~
注意:數據只要涉及多表一致性操作,必須要開啟數據庫事務操作
* 更多model示例請見附件4
- 序言及更新日志
- 前言一 開發PHP必備的環境(你可以不看)
- LinUX系統ThinkPHP5鏈接MsSQL數據庫的pdo_dblib擴展
- centos7.2掛載硬盤攻略
- Centos系統Redis安裝及Redis的PHP擴展安裝
- Centos系統增加Swap(系統交換區)的方法
- 前言二 開發PHP軟件配置和介紹(你依然可以不看)
- 數據庫SQL文件
- 本地Git(版本控制)的搭建
- GIT遠程倉庫的克隆和推送
- Git常用命令
- PHP面向對象思想實戰經驗領悟
- PHP面向對象實戰----命名空間
- PHP面向對象實戰----繼承
- 基類實戰--底層方法封裝
- 基類實戰--構造函數實戰
- 基類實戰--析構函數的使用
- TP5實戰開發前篇---控制器(controller)
- 控制器中Request類的使用
- 控制器中基類的使用
- TP5實戰開發前篇---模型篇(model)
- TP5實戰開發前篇---驗證器篇(Validate)
- TP5實戰課程入門篇---花拳繡腿
- 模塊以及類的文件的建立
- Api開發------單條信息顯示
- Api開發---單條信息復雜關聯顯示
- Api開發---查詢信息緩存Cache的應用
- TP5實戰技巧---開發思路 引路造橋
- TP5實戰技巧---整合基類 化繁為簡
- TP5實戰課程入門篇---數據操作
- Api開發---數據的添加和修改
- API開發---快速開發API通用接口
- TP5專用微信sdk使用教程
- THINKPHP5微信SDK更新記錄及升級指導
- TP5專用SDK 微信參數配置方法
- 微信公眾號推送接口對接教程
- 微信推送接口對接示例含掃描登錄微信端部分
- TP5專用微信支付SDK使用簡介
- TP5專用支付寶支付SDK使用說明
- 使用NW將開發的網站打包成桌面應用
- TP5高階實戰課程 進階篇概述
- 進階篇一 實戰開發之習慣及要求
- 進階篇二 實戰開發之控制器
- 控制器基類之控制器基類使用方法
- 控制器基類之控制器基類常用方法分享
- 控制器基類之構造函數的使用方法
- 進階篇三 實戰開發之權限控制
- TP5實戰源碼 --- 全局用戶信息驗證類Auth
- TP5實戰源碼 --- 微信Auth實戰開發源碼
- 進階篇四 實戰開發之模型
- 模型基類之模型基類的用途
- 模型基類之常用數據處理方法
- 模型邏輯層之實戰代碼(含事務)
- 模型實戰開發之模型常用方法
- 模型實戰源碼 --- 樂觀鎖的應用
- 模型實戰技巧---Model事件功能的使用
- 模型事件實戰應用---數據庫操作日志
- 進階篇五 實戰開發之緩存(Cache)
- TP5實戰源碼---應用緩存獲取城市信息
- TP5實戰源碼---應用緩存獲取分類詳情
- 進階篇六 TP5類庫的封裝和使用
- DataEdit快捷操作類庫
- ShowCode快捷使用類庫
- 阿里大于 短信API接口 TP5專用類庫
- DatabaseUpgrade數據庫對比及更新類庫
- AuthWeb權限類使用說明
- 進階篇七 服務層的應用
- 服務層源碼示例
- 服務層基類源碼
- 進階篇八 應用層Redis數據處理基類
- Redis服務層基類源碼
- 進階篇九 使用Redis類庫處理一般的搶購(秒殺)活動示例
- 進階篇十 某大型項目應用本Redis類源碼示例(含事務 樂觀鎖)
- 進階篇十一 邏輯層的應用
- 邏輯層基類源碼
- 進階篇 服務層代碼示例
- 高階實戰課程 進階篇持續新增中
- 高階篇一 TP5命令行之守護任務源碼
- TP5實戰源碼 --- 命令行
- TP5實戰源碼 --- 通過shell建立PHP守護程序
- 高階篇二 使用Redis隊列發送微信模版消息
- 高階篇二 之 Worker隊列基類源碼
- 高階篇三 TP5實戰之Redis緩存應用
- Redis實戰源碼之Hash專用類庫源碼
- Redis實戰源碼之Model類結合
- Redis實戰源碼之模型Hash基類源碼
- Redis實戰源碼之Hash查詢使用技巧
- Redis實戰源碼之 shell腳本中redis賦值和取值
- 高階篇四 Swoole的實戰應用
- swoole基類代碼
- Swoole擴展WebsocketServer專用類
- 基于Swoole的多Room聊天室的程序
- Swoole守護服務shell源碼
- 高階篇五 命令行異步多進程隊列類的應用
- tp_worker類源碼
- WorkerBase
- WorkerCommand
- WorkerRedis
- Redis類
- CycleWorkBase
- WorkerHookBase異步鉤子
- 隊列日志SQL
- 高階篇六 定時執行隊列類庫以及使用方法
- 定時隊列類庫源碼
- 高階篇七 異步執行循環隊列類庫以及使用教程
- CycleWorkBase源碼
- 高階實戰課程 進階篇持續新增中
- Extend便捷類庫源碼庫
- 阿里相關類庫
- SendSms--驗證碼API接口文件
- 權限相關類庫目錄
- AuthWeb 權限驗證類庫
- Redis便捷操作類庫(20171224更新)
- Redis
- Tools工具類庫集
- Curl類庫
- DataEdit
- Rand類庫
- ShowCode類庫
- Upload類庫
- 附件集合
- 附件一:微信支付 實戰開發源碼
- 微信支付類庫源代碼
- Common_util_pub.php
- DownloadBill_pub.php
- JsApi_pub.php
- NativeCall_pub.php
- NativeLink_pub.php
- OrderQuery_pub.php
- Refund_pub.php
- RefundQuery_pub.php
- SDKRuntimeException.php
- ShortUrl_pub.php
- UnifiedOrder_pub.php
- Wxpay_client_pub.php
- Wxpay_server_pub.php
- WxPayConf_pub.php
- 微信支付回調頁面源碼
- 附件二 順豐快遞BSP接口實戰開發源碼
- 順豐快遞BSP接口實戰開發源碼
- 順豐BSP基類
- 順豐BSP基礎代碼
- 順豐BSP下單接口
- 順豐BSP查單接口
- 順豐BSP確認/取消接口
- 附件三 APP注冊登陸接口源碼(含融云平臺接口)
- 附件四 TP5訂單Model(含事務 獲取器 修改器等方法)
- 附錄五 RSA加密解密
- Rsa文件源碼
- 附件六 阿里大于短信接口
- 附件七 AES加解密類
- AES加解密類源碼
- 附件八 TP5路由設置源碼
- 附件九 TP5 Excel導入導出下載便捷類庫
- Excel類庫TP5源碼
- 附件十 TP5便捷操作Redis類庫源碼
- TP5源碼 Redis操作便捷類庫
- 附件十一 TP5源碼 上傳文件入庫類源碼
- 上傳類Upload源碼
- Upload類上傳配置文件
- 存儲圖像文件的數據庫SQL文件
- 存儲文件的數據庫SQL文件
- 附件十二 TP5 圖片處理增強類 支持縮略圖在線顯示
- 附件十三 微信推送消息接口類庫源碼
- 附件十三 微信推送消息接口類庫源碼 之 基類
- 附件十四 存儲微信昵稱的處理方法