您好,登錄后才能下訂單哦!
這篇文章給大家介紹如何在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分表方法就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。