### 2018 年 12 月 31 日 發(fā)布
本文內(nèi)容主要介紹下ThinkPHP`5.2`目前版本的數(shù)據(jù)庫和模型操作相對于`5.1`版本的一些變化區(qū)別。
總體來說,在數(shù)據(jù)庫和模型層面,`5.2`的改動并不大,只是因為強類型變量的約束會導(dǎo)致一些用法的差異,以及一些統(tǒng)一和廢棄的方法會導(dǎo)致查詢代碼的調(diào)整。
>[danger] `5.2`版本目前尚未正式發(fā)布,在正式發(fā)布之前可能仍然會存在變化。
## 新特性
在`5.1`最新版本的基礎(chǔ)上,改進和新增了一些功能特性。
### 強類型嚴格模式
新版核心全面啟用了嚴格模式,避免因為方法參數(shù)類型模糊而導(dǎo)致的規(guī)范不一或者潛在問題。
### `Db`使用門面對象
新版的`Db`類不再是靜態(tài)類,需要使用`think\facade\Db`門面進行靜態(tài)代理。
```
\think\facade\Db::name('user')->find();
```
### 重構(gòu)的`fetchSql`方法
查詢類的`fetchSql`方法返回了一個新的`think\db\Fetch`類,獲取查詢SQL的操作和查詢操作完全隔離。另外一個副作用是可以使得查詢方法的返回值更加規(guī)范。`Fetch`類目前已經(jīng)支持動態(tài)查詢方法。
```
Db::name('user')->where('id', 1); // 返回\think\db\Query對象實例
Db::name('user')->where('id', 1)->fetchSql(); // 返回\think\db\Fetch對象實例
```
### 增加樂觀鎖功能
和軟刪除一樣,增加了一個`think\model\concern\OptimLock`Trait用于方便引入擴展模型的樂觀鎖功能。
```
<?php
namespace app\index\model;
use think\model\conern\OptimLock;
use think\Model;
class User extends Model
{
use OptimLock;
protected $optimLock = 'lock_version';
}
```
### 增加`fetchArray`方法
模型的查詢可以通過顯式調(diào)用`fetchArray`方法使得查詢結(jié)果返回數(shù)組而不是模型對象和數(shù)據(jù)集,適用于一些圖表控件的數(shù)據(jù)輸出。
```
// 返回模型對象
User::find(1);
// 返回數(shù)組
User::fetchArray()->find(1);
```
### 模型增加`Schema`定義
模型類增加`schema`屬性,用于**完整定義**模型對應(yīng)數(shù)據(jù)表的字段信息,可以避免查詢的時候獲取數(shù)據(jù)表字段信息而無需生成`Schema`緩存。并且該屬性中定義字段類型支持使用`php`類型定義。需要注意和`field`/`type`屬性的區(qū)別,field屬性僅用于定義當前模型允許寫入的字段,而`type`屬性則僅用于定義數(shù)據(jù)字段的類型強制轉(zhuǎn)換。
```
<?php
namespace app\index\model;
use think\Model;
class User extends Model
{
protected $schema = [
'id' => 'int',
'name' => 'string',
'score' => 'float',
'create_time' => 'datetime',
'update_time' => 'datetime',
'delete_time' => 'datetime',
];
}
```
### 模型延遲保存機制
模型增加延遲保存方法`lazySave`,調(diào)用該方法后不會馬上保存數(shù)據(jù),僅僅是保存在內(nèi)存中,當前模型對象銷毀的時候或者下次顯式調(diào)用`save`方法的時候都會自動保存到數(shù)據(jù)庫。
```
$user = User::find(1);
$user->name = 'thinkphp';
$user->lazySave();
...
$user->score = 100;
$user->save();
```
### `join`系列方法增加參數(shù)綁定支持
`join`方法(包括`leftJoin`/`rightJoin`/`fullJoin`方法)支持手動參數(shù)綁定。
### 增加`tableRaw`方法
增加`tableRaw`方法使用表達式方法定義當前查詢的數(shù)據(jù)表。
### 查詢緩存支持閉包情況
改進查詢緩存方法支持使用閉包查詢的情況。
### 增加`withAttrs`方法
由于參數(shù)強制類型的關(guān)系,`withAttr`方法不支持傳入數(shù)組,必須使用`withAttrs`方法傳入數(shù)組批量設(shè)置字段獲取器。
## 廢棄功能和方法
廢棄了一些目前已經(jīng)很少用到或者不建議使用的功能,以及對容易混淆的一個功能多個用法進行了統(tǒng)一。
### 數(shù)據(jù)分表功能
取消了數(shù)據(jù)庫分表功能,建議直接使用數(shù)據(jù)庫的分區(qū)功能替代,更靈活和性能更好,同時取消了`Query`類的`getPartitionTableName`和`partition`方法。
### 取消了`get`/`all`方法
無論使用`Db`類還是模型類查詢,全部統(tǒng)一使用`find`/`select`方法,取消了之前模型類額外提供的`get`/`all`方法。
### 取消`findOrEmpty`方法
取消了Query類的`findOrEmpty`方法,當模型使用`find`方法查詢的時候,數(shù)據(jù)不存在自動返回一個空模型對象,無需再使用`findOrEmpty`方法了。
### 取消`relation`方法
取消了Query類的`relation`方法,模型的關(guān)聯(lián)獲取直接使用關(guān)聯(lián)屬性方式惰性獲取。
### 取消了`readMaster`方法
取消了Query類和模型類的`readMater`方法,由于該方法使用了靜態(tài)屬性容易導(dǎo)致Swoole等常駐內(nèi)存的環(huán)境下讀取錯亂。需要的時候可以用`master`方法手動切換主庫讀取。
### 取消`fetchPdo`方法
取消了Query類的`fetchPdo`方法,需要的時候直接使用`getPdo`方法替代。
### 取消查詢方法傳入`Query`對象
取消Query類的CURD查詢方法傳入當前對象,如果需要請使用閉包替代。
### 取消全局查詢范圍`base`方法
取消模型類的全局查詢范圍`base`方法,改由使用`globalScope`屬性定義(數(shù)組)需要全局查詢的查詢范圍方法。或者在`db($scope)`方法中傳入全局查詢范圍。如果是靜態(tài)查詢,可以使用`useGlobalScope($scope)`。
### 取消`db`和`model`助手函數(shù)
這兩個助手函數(shù)`5.1`版本已經(jīng)不再建議使用了,新版直接廢棄掉這兩個助手函數(shù),請指教使用`\think\facade\Db`類和實際的模型類調(diào)用。
### 取消`setInc`/`setDec`方法
取消Query類的`setInc`/`setDec`方法,統(tǒng)一使用`inc`/`dec`方法替代,同時改進了`inc`/`dec`方法支持延時更新。
## 取消`setField`方法
取消Query類的`setField`方法,請直接使用`data`方法或者`update`方法。
### 取消`__TABLE_NAME__`支持
`table`方法取消`__TABLE_NAME__`支持,必須明確調(diào)用完整表名或者使用`name`方法。
### 取消`whereOr`等方法傳入`Query`對象
除了`where`方法本身可以傳入`Query`對象外,其它的所有`where`查詢方法(例如`whereOr`/`whereExp`等)都不再支持傳入`Query`對象。
### 取消`resultset_type`配置參數(shù)
數(shù)據(jù)集查詢結(jié)果不再受`resultset_type`配置參數(shù)影響,默認情況下,Db查詢統(tǒng)一返回數(shù)組,模型查詢統(tǒng)一返回模型對象和模型數(shù)據(jù)集對象。如果Db查詢的時候也需要返回數(shù)據(jù)集的話,可以顯式調(diào)用`fetchCollection`方法。
### `with`方法和`withJoin`獨立
無需在模型關(guān)聯(lián)方法中定義是否使用JOIN查詢,只有在明確調(diào)用`withJoin`的時候才會使用JOIN查詢。
- 值得升級到5.1的18個理由
- 5.1.7版本新特性
- JSON字段類型在ORM中的使用
- 文件下載響應(yīng)對象
- 教你使用5.1的數(shù)組對象查詢
- 模型三大利器之一:搜索器
- 在ThinkPHP中使用Yaconf
- 掌握命令行的表格輸出
- 5.1.25查詢參數(shù)綁定的改進
- ThinkPHP安全規(guī)范指引
- 巧用數(shù)據(jù)集的排序功能實現(xiàn)統(tǒng)計排序
- think-orm ——基于5.1的獨立ORM庫
- think-template——基于ThinkPHP的獨立模板引擎
- ThinkPHP5.1.26版本發(fā)布——修正版本,包含安全更新
- ThinkPHP5.0和3.2再發(fā)安全更新
- 官宣:ThinkPHP發(fā)布首個LTS版本
- 你真的了解Db類和模型的正確使用姿勢么?
- 如何更有效的記錄和管理日志
- 模型三大利器之二:修改器
- ThinkPHP5.1.28版本發(fā)布——修正上一版本問題,改進關(guān)聯(lián)查詢
- 模型三大利器之三:獲取器
- API版本控制的幾種思路
- ThinkPHP5.2第一個Beta版本發(fā)布測試
- 讓你少犯錯的數(shù)據(jù)查詢基本原則
- ThinkPHP發(fā)布5.1.29版本——常規(guī)更新
- 這15個好習(xí)慣讓你更容易升級到5.2
- 如何有效提高ThinkPHP的應(yīng)用性能
- 讓你提高開發(fā)效率的查詢技巧
- 模型關(guān)聯(lián)查詢不完全指南
- 5.2發(fā)布Beta2版本——統(tǒng)一和精簡大量用法
- ThinkPHP發(fā)布5.1.30版本——支持微秒時間字段寫入
- ThinkPHP的數(shù)據(jù)緩存使用
- ThinkPHP5.2安裝及入口文件
- ThinkPHP榮獲2018 年度最受歡迎中國開源開發(fā)框架第1名
- 5.1路由使用心得技巧
- ThinkPHP5.*版本發(fā)布安全更新
- ThinkPHP項目及代碼規(guī)范指北
- 5.2版本的設(shè)計規(guī)范指導(dǎo)
- ThinkPHP5.1.32版本發(fā)布——圣誕快樂
- 利用Trait特性給模型增加樂觀鎖功能
- 5.2數(shù)據(jù)庫和模型的變化(摘要)
- ThinkPHP模板引擎實現(xiàn)和常見問題
- ThinkPHP5.0.24版本發(fā)布——安全更新
- 不忘初心,方得始終——ThinkPHP十三周年報告
- ThinkPHP5+相關(guān)資源匯總
- 異步社區(qū)ThinkPHP周年慶專享優(yōu)惠活動
- 5.2路由的調(diào)整和改進
- ThinkPHP發(fā)布5.1.33版本——包含安全更新
- ThinkPHP擴展開發(fā)指南
- ThinkPHP發(fā)布5.2Beta3版本
- ThinkPHP發(fā)布5.1.34版本——喜迎新年
- ThinkPHP發(fā)布5.2RC1版本
- ThinkPHP發(fā)布5.1.35版本——常規(guī)更新
- 5.2配置類的調(diào)整
- 5.2時間查詢的改進和優(yōu)化
- 5.2RC版本升級不完全指導(dǎo)(僅供學(xué)習(xí)參考)
- ThinkPHP5.2版本正式變更為6.0版本
- ThinkPHP百度云云虛擬主機專享免費活動
- 事件系統(tǒng)以及查詢事件、模型事件的使用
- ThinkPHP6.0RC2版本發(fā)布——架構(gòu)升級、精簡核心
- ThinkPHP5.1.36LTS版本發(fā)布——常規(guī)更新
- 新版Session和Cookie設(shè)計變化
- ThinkPHP5.1.37版本發(fā)布——常規(guī)更新
- ThinkPHP6.0RC3版本發(fā)布——細節(jié)完善,體驗優(yōu)化
- 6.0中間件使用詳解
- Composer各大廠商鏡像地址
- ThinkPHP6.0發(fā)布計劃公告
- 「ThinkPHP開發(fā)者周刊」招募志愿者
- ThinkPHP6.0日志變化
- ThinkPHP5.1.38版本發(fā)布——常規(guī)更新
- ThinkPHP6.0RC4版本發(fā)布——ORM獨立,日志多通道支持
- ThinkORM2.0開發(fā)指南上線
- ThinkPHP6.0RC5版本發(fā)布——多應(yīng)用模式獨立,中間件機制調(diào)整
- ThinkPHP6.0版本發(fā)布——程序員節(jié)福利
- ThinkPHP5.1.39LTS版本發(fā)布——常規(guī)更新
- ThinkPHP6.0.1版本發(fā)布——圣誕快樂!
- 回顧2019,展望2020!
- ThinkPHPV6.0.2版本發(fā)布——2020新春快樂!
- 周年福利系列:Swoole合作優(yōu)惠
- 億速云成為ThinkPHPV6.0獨家贊助發(fā)布商??
- 新冠疫情工具和限免資源專題(保持更新中)
- 周年福利系列:創(chuàng)宇信用認證合作優(yōu)惠
- 周年福利系列:碼云企業(yè)版限時10%優(yōu)惠
- 周年福利系列:想天短說抵現(xiàn)優(yōu)惠
- think-swoole直播:從零開始掌握swoole開發(fā)
- 周年福利系列:B2C開源電商ShopXO授權(quán)8折優(yōu)惠
- 周年福利系列:LayuiAdmin 永久授權(quán)限時優(yōu)惠
- ThinkPHP資源導(dǎo)航站上線——構(gòu)建生態(tài) 服務(wù)未來
- ThinkPHP官方技術(shù)支持服務(wù)和應(yīng)用服務(wù)市場上線公測
- ThinkPHP市場精選——推廣基本要素
- ThinkPHP市場精選——客服聊天專題
- ThinkPHPV6.0.3版本發(fā)布——端午安康
- ThinkPHP開發(fā)者扶持計劃
- 6.0.3版本關(guān)鍵更新及升級事項
- 「ThinkPHP開發(fā)者周刊」改版重啟
- ThinkPHP市場精選——企業(yè)建站專題
- ThinkPHP 提供統(tǒng)一API接口服務(wù)
- ThinkPHP市場精選——直播電商專題
- ThinkAPI服務(wù)SDK發(fā)布
- 官方服務(wù)市場啟用獨立子域名
- ThinkPHP市場精選——刷臉支付專題
- ThinkAPI推出會員服務(wù)計劃
- ThinkPHPV6.0.4版本發(fā)布——中秋國慶雙節(jié)快樂
- ThinkPHPV5.1.40版本發(fā)布——常規(guī)更新
- 1024程序員節(jié)福利走一波
- ThinkPHP V6.0.5版本發(fā)布——兼容Composer2.0
- 知識圖譜應(yīng)用場景——源論技術(shù)沙龍
- ThinkPHP5.*版本改進Composer2.0的兼容
- 官方市場雙十一精選推薦
- 技術(shù)人做產(chǎn)品有機會么(文末送課程)
- 本周秒殺——古德云售后獲客營銷系統(tǒng)
- ThinkAPI服務(wù)更新——支持接口分組和PHP版本依賴調(diào)整
- PHP8新特性盤點
- PHP8新特性系列:構(gòu)造器屬性提升使用及注意事項
- ThinkPHP2021新年寄語
- ThinkPHP V6.0.6&V5.1.41版本發(fā)布——兼容PHP8.0
- PHP如何更優(yōu)雅地調(diào)用API接口
- ThinkPHP V6.0.7發(fā)布——修正版本
- ThinkAPI服務(wù)更新——IP白名單
- 最新版ThinkORM對于時間字段的調(diào)整
- ThinkAPI短信接口正式上線
- ThinkPHP V6.0.8版本發(fā)布——多環(huán)境變量配置支持
- 頂想云寫作服務(wù)開啟第一次公測
- ThinkSSL上線——官方SSL/TLS證書服務(wù)
- MDBootstrap國內(nèi)用戶福利——ThinkPHP官方市場首發(fā)
- ThinkPHP V6.0.9版本發(fā)布——常規(guī)更新
- ThinkORM功能盤點——虛擬模型
- 全面支持主流GIT版本庫——云寫作服務(wù)第二次公測
- 云寫作服務(wù)私有化部署方案之:版本庫私有化
- 看云雙十一活動
- ThinkPHP V6.0.10LTS發(fā)布——兼容PHP8.1
- ThinkPHP V6.0.12發(fā)布——命令行兼容8.1
- 頂想云知識管理上線公測——構(gòu)建企業(yè)文檔中心和知識庫
- 頂想云上線——助力生態(tài)數(shù)字化建設(shè)
- 618活動進行中——官方市場迎來一波更新
- 頂想云知識管理正式上線——看云文檔啟動遷移服務(wù)
- ThinkPHP V6.0.13發(fā)布——常規(guī)更新
- 頂想云網(wǎng)站助理服務(wù)上線——構(gòu)建產(chǎn)品支持服務(wù)
- ThinkPHP發(fā)布6.1.0&6.0.14版本——安全更新
- ThinkPHP新版社區(qū)上線試運營
- ThinkAPI上架人臉核身接口——助力網(wǎng)站實名認證
- 辭舊迎新——舊版社區(qū)停止注冊及發(fā)帖
- ThinkPHP6.1.2版本發(fā)布——兼容PHP8.2
