亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何在Laravel中使用Eloquent分表方法

發布時間:2021-03-23 15:09:38 來源:億速云 閱讀:301 作者:Leah 欄目:開發技術

這篇文章給大家介紹如何在Laravel中使用Eloquent分表方法,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

首先我們先創建一個類名為 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);
  }
}

關于如何在Laravel中使用Eloquent分表方法就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

通海县| 海门市| 浑源县| 汕尾市| 岳阳市| 微山县| 车险| 格尔木市| 黑水县| 康平县| 宕昌县| 泰兴市| 息烽县| 廊坊市| 佛山市| 花莲县| 保康县| 田东县| 扎囊县| 静乐县| 喀喇沁旗| 蓝山县| 陆良县| 黄骅市| 建平县| 吉水县| 鲁山县| 平顺县| 鸡泽县| 日喀则市| 宕昌县| 梁河县| 汤阴县| 临安市| 怀来县| 丘北县| 定日县| 松江区| 楚雄市| 屯留县| 赣州市|