Laravel Eloquent 分表方法並使用模型關聯


眾所周知 Laravel 是 PHP 開發項目最優美的框架之一,尤其是 Eloquent 對數據庫的操作提供了特別多的便利。
在實際開發中我們經常涉及到分庫分表場景,那么怎樣才能繼續配合 Eloquent 優雅的使用 Model 模型呢,接下來給大家分享下我在實際開發中所遇到的問題。(備注:此方法來源 Stack OverFlow 原文地址找不到了,配合我們實際項目更能清晰表述)
1、假設我們有一萬本書籍,每本書籍有兩千章節,我們創建數據庫時的表結構是書籍信息表:books;以及章節信息表:chapters,前面說到書籍越多章節數也就越多解決方案是將章節表分成十個形式為 chapters_0、chapters_1、......chapters_9 表后綴規則是書籍 ID 與 10 取余,這樣所有的書籍章節會分散在這 10 個 chapters 中。
2、表建好后開始創建 model 模型,按照慣例所有的模型都將寫在 App\Models 下;首先我們先創建一個類名為 Model 的模型並繼承 Illuminate\Database\Eloquent\Model

<?php

namespace App\Models;

use Illuminate\Database\Eloquent\Model as EloquentModel;

class Model extends EloquentModel
{
    protected $suffix = null;

    // 設置表后綴
    public function setSuffix($suffix)
    {
        $this->suffix = $suffix;
        if ($suffix !== null) {
            $this->table = $this->getTable() . '_' . $suffix;
        }
    }

    // 提供一個靜態方法設置表后綴
    public static function suffix($suffix)
    {
        $instance = new static;
        $instance->setSuffix($suffix);

        return $instance->newQuery();
    }

    // 創建新的"chapters_{$suffix}"的模型實例並返回
    public function newInstance($attributes = [], $exists = false)
    {
        $model = parent::newInstance($attributes, $exists);
        $model->setSuffix($this->suffix);

        return $model;
    }
}

 

2、其他模型全都繼承以上的 Model 而不是繼承 Illuminate\Database\Eloquent\Model,獲取某本書的章節 controller

<?php

namespace App\Http\Controllers;

use App\Models\{Book, Chapter};

class ChaptersController extends Controller
{
    public function chapter (Book $book)
    {
        // 章節列表(普通查詢)
        $list = Chapter::lists($book->id);

        // 章節列表(使用模型關聯)
        $list = $book->chapters()->oldest('id')->get();
    }
}

3、chapter 模型(普通查詢)

<?php

namespace App\Models;

class Chapter extends Model
{
    public static function lists ($bookId)
    {
        $suffix = $bookId % 10;
       /*
        * 例如 $sufiix = 1; 我要要獲取的就是:chapters_1的模型實例
        * 使用Model類中提供的靜態方法創建該表的模型實例
        * 返回指定書籍的章節
        */
        return self::suffix($suffix)->where('book_id', $bookId)->get();
    }
}

 

3、好了,我們章節的分表模型已經完成了。那么如何使用模型關聯呢?我們來看 Book 模型如何關聯 Chapter

<?php

namespace App\Models;

use Illuminate\Database\Eloquent\Relations\HasMany;

class Book extends Model
{
    public function chapters ()
    {
        /*
        * books表的id和chapters表中的book_id關聯
        * 一對多關系(一本書對應多條章節)
        */
        $instance = new Chapter();
        $instance->setSuffix($this->id % 10);

        $foreignKey = $instance->getTable . '.' . $this->getForeignKey();
        $localKey = $this->getKeyName();

        return new HasMany($instance->newQuery(), $this, $foreignKey, $localKey);
    }
}

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM