您好,登錄后才能下訂單哦!
這篇文章給大家介紹如何在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ò),可以把它分享出去讓更多的人看到。
免責(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)容。