您的位置:首页 > 网络编程 > PHP教程

Laravel Eloquent分表方法并使用模型关联的实现

作者:自由哥 来源:建站技术网

2022-12-12 08:57:11

众所周知 Laravel 是 PHP 开发项目最优美的框架之一,尤其是 Eloquent 对数据库的操作提供了特别多的便利。
在实际开发中我们经常涉及到分库分表场景,那么怎样才能继续配合 Eloquent 优雅的使用 Model 模型呢,接下来给大家分享下我在实际开发中所遇到的问题。(备注:此方法来源 Stack OverFlow 原文地址找不到了,配合我们实际项目更能清晰表述)

1、假设我们有一万本书籍,每本书籍有两千章节,我们创建数据库时的表结构是书籍信息表:books;以及章节信息表:chapters,前面说到书籍越多章节数也就越多解决方案是将章节表分成十个形式为 chapters_0、chapters_1、......chapters_9 表后缀规则是书籍 ID 与 10 取余,这样所有的书籍章节会分散在这 10 个 chapters 中。

2、表建好后开始创建 model 模型,按照惯例所有的模型都将写在 App/Models 下;首先我们先创建一个类名为 Model 的模型并继承 Illuminate/Database/Eloquent/Model

<?phpnamespace 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

<?phpnamespace 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 模型(普通查询)

<?phpnamespace 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

<?phpnamespace 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);  }}

到此 model 发表查询及 model 关联就完成了,如果有其他更好的方式,请大家不吝赐教。第一次发表文章,如有不对的地方希望大家多多指教!!也希望大家多多支持脚本之家。

猜你喜欢

本文实例讲述了laravel框架邮箱认证实现方法。分享给大家供大家参考,具体如下: 修改 User 模型,将 Laravel 自带的邮箱认证功能集成到我们的程序中<&#63;phpnam

2022-12-12 08:57:20

本文实例讲述了laravel框架语言包拓展实现方法。分享给大家供大家参考,具体如下: laravel 使用make:auth生成用户认证,登录表单是英文版本的,打开模板文件(re

2022-12-12 08:57:20

本文实例讲述了laravel框架创建授权策略。分享给大家供大家参考,具体如下:用户只能编辑自己的资料在完成对未登录用户的限制之后,接下来我们要限制的是已登录用户

2022-12-12 08:57:18

本文实例讲述了laravel框架中路由设置,路由参数和路由命名。分享给大家供大家参考,具体如下:laravel中必须先配置路由,才能使用。不像tp中不配置也能使用,因为

2022-12-12 08:57:18

本文实例讲述了laravel框架模型中非静态方法也能静态调用的原理.分享给大家供大家参考,具体如下:刚开始用laravel模型时,为了方便一直写静态方法,进行数据库操作

2022-12-12 08:57:16

本文实例讲述了laravel框架中控制器的创建和使用方法。分享给大家供大家参考,具体如下:laravel中我们可以使用 artisan 命令来帮助我们创建控制器文件。php artis

2022-12-12 08:57:16

本文实例讲述了laravel框架中表单请求类型和CSRF防护。分享给大家供大家参考,具体如下:laravel中为我们提供了绑定不同http请求类型的函数。Route::get('/test',

2022-12-12 08:57:15

本文实例讲述了laravel框架中视图的基本使用方法。分享给大家供大家参考,具体如下:laravel中的视图默认保存在 resources/views 目录下。在控制器中,我们通常使用

2022-12-12 08:57:15

前言:我也是昨晚看了黄岛主的直播后学会的这个方法,今天中午趁着休息时间,把这个技巧分享给大家。就是大家在调试 Hyperf 的时候,可能总需要做一些服务的重启,

2022-12-12 08:57:13

简介 在我们的开发过程中,我们不可避免的会用到版本控制。当然,这也致使你对 Git 和 SVN 有所了解。两者都是出色的版本控制工具,我个人比较习惯用 Git,当然这

2022-12-12 08:57:13

© 2007-2021 建站技术网版权所有联系QQ:2140427459