91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

如何在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

河间市| 丰顺县| 灵武市| 广饶县| 丰都县| 小金县| 宁阳县| 闵行区| 绥滨县| 靖州| 崇礼县| 龙井市| 团风县| 阜新| 武汉市| 彭州市| 应用必备| 孝感市| 咸宁市| 汶川县| 禹州市| 长宁县| 修文县| 洛川县| 乌什县| 都安| 华阴市| 黎平县| 洛浦县| 同德县| 青铜峡市| 拉萨市| 色达县| 锡林浩特市| 平罗县| 广东省| 铜陵市| 阿拉善右旗| 佛坪县| 凤冈县| 抚宁县|