好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > Laravel Eloquent分表方法并使用模型關聯的實現

Laravel Eloquent分表方法并使用模型關聯的實現

熱門標簽:高德地圖標注店鋪收費嗎 泊頭在哪里辦理400電話 欣思維地圖標注 天潤融通外呼系統好嗎 高德地圖標注位置怎么標注 杭州語音電銷機器人 江門回撥外呼系統 江西電銷機器人收費 電銷機器人沒有效果怎么樣

眾所周知 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);
  }
}

到此 model 發表查詢及 model 關聯就完成了,如果有其他更好的方式,請大家不吝賜教。第一次發表文章,如有不對的地方希望大家多多指教!!也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • laravel5.6 框架操作數據 Eloquent ORM用法示例
  • Laravel 手動開關 Eloquent 修改器的操作方法
  • laravel框架數據庫操作、查詢構建器、Eloquent ORM操作實例分析
  • Laravel框架Eloquent ORM新增數據、自定義時間戳及批量賦值用法詳解
  • Laravel框架Eloquent ORM簡介、模型建立及查詢數據操作詳解
  • Laravel框架Eloquent ORM修改數據操作示例
  • laravel7學習之無限級分類的最新實現方法
  • laravel admin實現分類樹/模型樹的示例代碼
  • 如何使用Laravel Eloquent來開發無限極分類

標簽:平涼 內江 大同 石嘴山 雙鴨山 深圳 江門 駐馬店

巨人網絡通訊聲明:本文標題《Laravel Eloquent分表方法并使用模型關聯的實現》,本文關鍵詞  Laravel,Eloquent,分表,方法,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Laravel Eloquent分表方法并使用模型關聯的實現》相關的同類信息!
  • 本頁收集關于Laravel Eloquent分表方法并使用模型關聯的實現的相關信息資訊供網民參考!
  • 推薦文章