Laravel Eloquent分表方法并使用模型关联的实现
时间:2022-07-27
本文章向大家介绍Laravel Eloquent分表方法并使用模型关联的实现,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
众所周知 Laravel 是 PHP 开发项目最优美的框架之一,尤其是 Eloquent 对数据库的操作提供了特别多的便利。 在实际开发中我们经常涉及到分库分表场景,那么怎样才能继续配合 Eloquent 优雅的使用 Model 模型呢,接下来给大家分享下我在实际开发中所遇到的问题。(备注:此方法来源 Stack OverFlow 原文地址找不到了,配合我们实际项目更能清晰表述)
1、假设我们有一万本书籍,每本书籍有两千章节,我们创建数据库时的表结构是书籍信息表:books;以及章节信息表:chapters,前面说到书籍越多章节数也就越多解决方案是将章节表分成十个形式为 chapters_0、chapters_1、……chapters_9 表后缀规则是书籍 ID 与 10 取余,这样所有的书籍章节会分散在这 10 个 chapters 中。
2、表建好后开始创建 model 模型,按照惯例所有的模型都将写在 AppModels 下;首先我们先创建一个类名为 Model 的模型并继承 IlluminateDatabaseEloquentModel
<?php
namespace AppModels;
use IlluminateDatabaseEloquentModel 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 而不是继承 IlluminateDatabaseEloquentModel,获取某本书的章节 controller
<?php
namespace AppHttpControllers;
use AppModels{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 AppModels;
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 AppModels;
use IlluminateDatabaseEloquentRelationsHasMany;
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 关联就完成了,如果有其他更好的方式,请大家不吝赐教。第一次发表文章,如有不对的地方希望大家多多指教!!也希望大家多多支持ZaLou.Cn。
- 如何在Kerberos的Linux上安装及配置Impala的ODBC驱动
- 对抗静态分析——so文件的加密
- Bypass unsafe-inline mode CSP
- Joomla未授权创建用户漏洞(CVE-2016-8870)分析
- 如何将HDFS文件系统挂载到Linux本地文件系统
- 使用 XML 内部实体绕过 Chrome 和 IE 的 XSS 过滤器
- 响应式编程的实践
- S2-045 原理初步分析(CVE-2017-5638)
- 如何在HDFS上查看YARN历史作业运行日志
- 面向流的设计思想
- 天才第一步 Docker 纸尿裤
- 如何迁移Kudu1.2的WAL和Data目录
- WordPress REST API 内容注入漏洞分析
- 如何为Kerberos环境的CDH集群在线扩容数据节点
- php概述
- php教程
- php环境搭建
- PHP书写格式
- php变量
- php常量
- PHP注释
- php数组
- php字符串 string
- PHP整型 integer
- PHP浮点型 float
- php布尔型
- php数据类型之数组
- php数据类型之对象
- php数据类型之null
- php数据类型之间的转换
- php运算符
- php表达式
- PHP循环控制
- PHP流程控制
- php函数
- php全局变量
- PHP魔术变量
- php命名空间
- php 日期
- PHP包含文件
- php文件
- PHP 文件上传
- php Cookies
- php Sessions
- php email
- php安全email
- php错误处理
- PHP异常处理
- php过滤器
- PHP 高级过滤器
- php json
- php 表单
- PHP MySQL 简介
- PHP 连接 MySQL
- php创建数据库
- php 创建表
- php mysq 插入数据
- PHP MySQL 插入多条数据
- PHP MySQL 预处理语句
- php mysql 读取数据
- php mysql where
- PHP MySQL Order By
- PHP MySQL Update
- PHP MySQL Delete
- php ODBC