欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Laravel Eloquent分表方法并使用模型關(guān)聯(lián)的實(shí)現(xiàn)

 更新時(shí)間:2019年11月25日 09:50:45   作者:Herbie  
這篇文章主要介紹了Laravel Eloquent分表方法并使用模型關(guān)聯(lián)的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

眾所周知 Laravel 是 PHP 開發(fā)項(xiàng)目最優(yōu)美的框架之一,尤其是 Eloquent 對(duì)數(shù)據(jù)庫(kù)的操作提供了特別多的便利。
在實(shí)際開發(fā)中我們經(jīng)常涉及到分庫(kù)分表場(chǎng)景,那么怎樣才能繼續(xù)配合 Eloquent 優(yōu)雅的使用 Model 模型呢,接下來給大家分享下我在實(shí)際開發(fā)中所遇到的問題。(備注:此方法來源 Stack OverFlow 原文地址找不到了,配合我們實(shí)際項(xiàng)目更能清晰表述)

1、假設(shè)我們有一萬本書籍,每本書籍有兩千章節(jié),我們創(chuàng)建數(shù)據(jù)庫(kù)時(shí)的表結(jié)構(gòu)是書籍信息表:books;以及章節(jié)信息表:chapters,前面說到書籍越多章節(jié)數(shù)也就越多解決方案是將章節(jié)表分成十個(gè)形式為 chapters_0、chapters_1、......chapters_9 表后綴規(guī)則是書籍 ID 與 10 取余,這樣所有的書籍章節(jié)會(huì)分散在這 10 個(gè) chapters 中。

2、表建好后開始創(chuàng)建 model 模型,按照慣例所有的模型都將寫在 App\Models 下;首先我們先創(chuàng)建一個(gè)類名為 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,獲取某本書的章節(jié) controller

<?php

namespace App\Http\Controllers;

use App\Models\{Book, Chapter};

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

    // 章節(jié)列表(使用模型關(guān)聯(lián))
    $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的模型實(shí)例
    * 使用Model類中提供的靜態(tài)方法創(chuàng)建該表的模型實(shí)例
    * 返回指定書籍的章節(jié)
    */
    return self::suffix($suffix)->where('book_id', $bookId)->get();
  }
}

3、好了,我們章節(jié)的分表模型已經(jīng)完成了。那么如何使用模型關(guān)聯(lián)呢?我們來看 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)系(一本書對(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ā)表查詢及 model 關(guān)聯(lián)就完成了,如果有其他更好的方式,請(qǐng)大家不吝賜教。第一次發(fā)表文章,如有不對(duì)的地方希望大家多多指教??!也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論