溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

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

發(fā)布時(shí)間:2021-03-23 15:09:38 來(lái)源:億速云 閱讀:292 作者:Leah 欄目:開(kāi)發(fā)技術(shù)

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

首先我們先創(chuàng)建一個(gè)類(lèi)名為 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,獲取某本書(shū)的章節(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類(lèi)中提供的靜態(tài)方法創(chuàng)建該表的模型實(shí)例
    * 返回指定書(shū)籍的章節(jié)
    */
    return self::suffix($suffix)->where('book_id', $bookId)->get();
  }
}

3、好了,我們章節(jié)的分表模型已經(jīng)完成了。那么如何使用模型關(guān)聯(lián)呢?我們來(lái)看 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)系(一本書(shū)對(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);
  }
}

關(guān)于如何在Laravel中使用Eloquent分表方法就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI