Laravel Eloquent分表方法并使用模型關(guān)聯(lián)的實(shí)現(xiàn)
眾所周知 Laravel 是 PHP 開(kāi)發(fā)項(xiàng)目最優(yōu)美的框架之一,尤其是 Eloquent 對(duì)數(shù)據(jù)庫(kù)的操作提供了特別多的便利。
在實(shí)際開(kāi)發(fā)中我們經(jīng)常涉及到分庫(kù)分表場(chǎng)景,那么怎樣才能繼續(xù)配合 Eloquent 優(yōu)雅的使用 Model 模型呢,接下來(lái)給大家分享下我在實(shí)際開(kāi)發(fā)中所遇到的問(wèn)題。(備注:此方法來(lái)源 Stack OverFlow 原文地址找不到了,配合我們實(shí)際項(xiàng)目更能清晰表述)
1、假設(shè)我們有一萬(wàn)本書(shū)籍,每本書(shū)籍有兩千章節(jié),我們創(chuàng)建數(shù)據(jù)庫(kù)時(shí)的表結(jié)構(gòu)是書(shū)籍信息表:books;以及章節(jié)信息表:chapters,前面說(shuō)到書(shū)籍越多章節(jié)數(shù)也就越多解決方案是將章節(jié)表分成十個(gè)形式為 chapters_0、chapters_1、......chapters_9 表后綴規(guī)則是書(shū)籍 ID 與 10 取余,這樣所有的書(shū)籍章節(jié)會(huì)分散在這 10 個(gè) chapters 中。
2、表建好后開(kāi)始創(chuàng)建 model 模型,按照慣例所有的模型都將寫(xiě)在 App\Models 下;首先我們先創(chuàng)建一個(gè)類(lèi)名為 Model 的模型并繼承 Illuminate\Database\Eloquent\Model
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Model as EloquentModel;
class Model extends EloquentModel
{
protected $suffix = null;
// 設(shè)置表后綴
public function setSuffix($suffix)
{
$this->suffix = $suffix;
if ($suffix !== null) {
$this->table = $this->getTable() . '_' . $suffix;
}
}
// 提供一個(gè)靜態(tài)方法設(shè)置表后綴
public static function suffix($suffix)
{
$instance = new static;
$instance->setSuffix($suffix);
return $instance->newQuery();
}
// 創(chuàng)建新的"chapters_{$suffix}"的模型實(shí)例并返回
public function newInstance($attributes = [], $exists = false)
{
$model = parent::newInstance($attributes, $exists);
$model->setSuffix($this->suffix);
return $model;
}
}
2、其他模型全都繼承以上的 Model 而不是繼承 Illuminate\Database\Eloquent\Model,獲取某本書(shū)的章節(jié) controller
<?php
namespace App\Http\Controllers;
use App\Models\{Book, Chapter};
class ChaptersController extends Controller
{
public function chapter (Book $book)
{
// 章節(jié)列表(普通查詢(xún))
$list = Chapter::lists($book->id);
// 章節(jié)列表(使用模型關(guān)聯(lián))
$list = $book->chapters()->oldest('id')->get();
}
}
3、chapter 模型(普通查詢(xún))
<?php
namespace App\Models;
class Chapter extends Model
{
public static function lists ($bookId)
{
$suffix = $bookId % 10;
/*
* 例如 $sufiix = 1; 我要要獲取的就是:chapters_1的模型實(shí)例
* 使用Model類(lèi)中提供的靜態(tài)方法創(chuàng)建該表的模型實(shí)例
* 返回指定書(shū)籍的章節(jié)
*/
return self::suffix($suffix)->where('book_id', $bookId)->get();
}
}
3、好了,我們章節(jié)的分表模型已經(jīng)完成了。那么如何使用模型關(guān)聯(lián)呢?我們來(lái)看 Book 模型如何關(guān)聯(lián) Chapter
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Relations\HasMany;
class Book extends Model
{
public function chapters ()
{
/*
* books表的id和chapters表中的book_id關(guān)聯(lián)
* 一對(duì)多關(guān)系(一本書(shū)對(duì)應(yīng)多條章節(jié))
*/
$instance = new Chapter();
$instance->setSuffix($this->id % 10);
$foreignKey = $instance->getTable . '.' . $this->getForeignKey();
$localKey = $this->getKeyName();
return new HasMany($instance->newQuery(), $this, $foreignKey, $localKey);
}
}
到此 model 發(fā)表查詢(xún)及 model 關(guān)聯(lián)就完成了,如果有其他更好的方式,請(qǐng)大家不吝賜教。第一次發(fā)表文章,如有不對(duì)的地方希望大家多多指教??!也希望大家多多支持腳本之家。
- laravel5.6 框架操作數(shù)據(jù) Eloquent ORM用法示例
- Laravel 手動(dòng)開(kāi)關(guān) Eloquent 修改器的操作方法
- laravel框架數(shù)據(jù)庫(kù)操作、查詢(xún)構(gòu)建器、Eloquent ORM操作實(shí)例分析
- Laravel框架Eloquent ORM新增數(shù)據(jù)、自定義時(shí)間戳及批量賦值用法詳解
- Laravel框架Eloquent ORM簡(jiǎn)介、模型建立及查詢(xún)數(shù)據(jù)操作詳解
- Laravel框架Eloquent ORM修改數(shù)據(jù)操作示例
- laravel7學(xué)習(xí)之無(wú)限級(jí)分類(lèi)的最新實(shí)現(xiàn)方法
- laravel admin實(shí)現(xiàn)分類(lèi)樹(shù)/模型樹(shù)的示例代碼
- 如何使用Laravel Eloquent來(lái)開(kāi)發(fā)無(wú)限極分類(lèi)
相關(guān)文章
淺談PHP攔截器之__set()與__get()的理解與使用方法
下面小編就為大家?guī)?lái)一篇淺談PHP攔截器之__set()與__get()的理解與使用方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-10-10
PHP CURL采集百度搜尋結(jié)果圖片不顯示問(wèn)題的解決方法
這篇文章主要介紹了PHP CURL采集百度搜尋結(jié)果圖片不顯示問(wèn)題的解決方法,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-02-02
Laravel統(tǒng)計(jì)一段時(shí)間間隔的數(shù)據(jù)方法
今天小編就為大家分享一篇Laravel統(tǒng)計(jì)一段時(shí)間間隔的數(shù)據(jù)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-10-10
PHP SPL標(biāo)準(zhǔn)庫(kù)之接口(Interface)詳解
這篇文章主要介紹了PHP SPL標(biāo)準(zhǔn)庫(kù)之接口(Interface)詳解,本文分別講解了Coutable接口、OuterIterator接口、RecursiveIterator接口、SeekableIterator接口、SplObserver和SplSubject接口等內(nèi)容,需要的朋友可以參考下2015-05-05
基于PHP讀取TXT文件向數(shù)據(jù)庫(kù)導(dǎo)入海量數(shù)據(jù)的方法
本篇文章小編為大家介紹,基于PHP讀取TXT文件向數(shù)據(jù)庫(kù)導(dǎo)入海量數(shù)據(jù)的方法。需要的朋友參考下2013-04-04
新版php?study根目錄下文件夾無(wú)法顯示的圖文解決方法
這篇文章主要介紹了新版php?study根目錄下文件夾無(wú)法顯示解決方法,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-12-12
Laravel自動(dòng)生成UUID,從建表到使用詳解
今天小編就為大家分享一篇Laravel自動(dòng)生成UUID,從建表到使用詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-10-10
微信小程序 消息推送php服務(wù)器驗(yàn)證實(shí)例詳解
這篇文章主要介紹了微信小程序 消息推送php服務(wù)器驗(yàn)證實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-03-03

