首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

自定义键的Laravel多态关系

在 Laravel 中,多态关系是一种强大的功能,它允许一个模型在多个其他类型的模型上拥有关联。自定义键的多态关系是指在多态关系中使用自定义的外键和类型字段,而不是使用 Laravel 默认的字段名。

基础概念

多态关系涉及三个主要部分:

  1. 外键字段:存储关联模型的 ID。
  2. 类型字段:存储关联模型的类名。
  3. 关联模型:实际与之关联的模型。

自定义键的优势

  • 灵活性:允许开发者根据具体需求自定义字段名,使数据库结构更加符合业务逻辑。
  • 可读性:自定义字段名可以提高代码的可读性和维护性。

类型与应用场景

类型

  • 一对一:一个模型与另一个模型一对一关联。
  • 一对多:一个模型与多个其他模型关联。
  • 多对多:多个模型与多个其他模型关联。

应用场景

  • 评论系统:一条评论可以属于一篇文章或一个视频。
  • 标签系统:一个标签可以关联到多种不同类型的模型。
  • 文件管理:一个文件可以属于多个不同类型的实体。

示例代码

假设我们有一个 Comment 模型,它可以属于 PostVideo 模型,并且我们希望使用自定义的外键和类型字段。

数据库迁移

代码语言:txt
复制
Schema::create('comments', function (Blueprint $table) {
    $table->id();
    $table->unsignedBigInteger('commentable_id');
    $table->string('commentable_type');
    $table->text('body');
    $table->timestamps();
});

模型定义

代码语言:txt
复制
class Comment extends Model
{
    public function commentable()
    {
        return $this->morphTo(__FUNCTION__, 'commentable_type', 'commentable_id');
    }
}

class Post extends Model
{
    public function comments()
    {
        return $this->morphMany(Comment::class, 'commentable', 'commentable_type', 'commentable_id');
    }
}

class Video extends Model
{
    public function comments()
    {
        return $this->morphMany(Comment::class, 'commentable', 'commentable_type', 'commentable_id');
    }
}

常见问题及解决方法

问题:为什么关联查询结果不正确?

原因:可能是由于自定义字段名与默认字段名不一致导致的。

解决方法:确保在模型中正确指定了自定义字段名。

代码语言:txt
复制
return $this->morphTo(__FUNCTION__, 'custom_type_field', 'custom_id_field');

问题:如何处理自定义字段名的验证?

解决方法:可以在模型中使用 $fillable 属性来指定允许批量赋值的字段。

代码语言:txt
复制
protected $fillable = ['commentable_id', 'custom_type_field', 'body'];

总结

自定义键的多态关系提供了更高的灵活性和可读性,但也需要开发者更加注意字段名的正确配置。通过上述示例和解决方法,可以有效地管理和维护多态关系。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

Laravel 多态关系的表单验证

相信大家使用 Laravel 开发应用的时候都会有评论模块吧,而且我们通常将该模块设计为多态关系(如果你对这个关系还不明白的话,请赶紧打开 Laravel 文档数据库关系章节复习一遍吧!)。...一般来讲有两种方式,而我们通常用的一种是从父模型使用关系写入,比如我们有一个 App\Thread 类,它里面对评论的关系是这样的: class Thread {    public function...comments() {            $this->morphToMany(Comment::class, 'commentable');    } } 然后我们的写入评论时通常是这样的...是不是简单很多,而且这样验证规则还能重用在其它同类多态关系的地方哦。 这样就结束了么?没有! 我们上面的拓展验证规则的写法没有感觉有些粗暴么?是时候规范一下了。...我们应该把所有的验证器都独立成一个类,放到 App\Validators 空间下,比如上面的关系验证我们可以叫做 App\Validators\PolyExistsValidator: <?

2.2K40

一种 Laravel 中简单设置多态关系模型别名的方式

作为 Laravel 的重度使用者肯定都对多态关系不陌生,以官方文档为例,文章有标签,视频有标签,那么文章和视频这些模型与标签模型的关系就是多态多对多(Many To Many (Polymorphic...))[1] 如果我们给 ID 为 1 的文章打上两个标签,数据库标签关系表的的存储结果就是这样子: > select * from taggables; +--------+-------------+...思路来源 我尝试跟踪了一遍源码,发现模型中有一个方法 getMorphClass,多态关联的时候,就是用它来取目标对象的类型名称的,默认返回类名: public function getMorphClass...》[2] 我们的目标是使用表名来做为关系类别名,那么在模型中如何获取表名呢,直接使用模型的 getTable 即可,那么整个 trait 的实现如下: app/Traits/UseTableNameAsMorphClass.php...References [1] 多态多对多(Many To Many (Polymorphic)): https://laravel.com/docs/6.x/eloquent-relationships

2.7K10
  • Laravel之Eloquent ORM

    应用Active Record时,每一个类的实例对象唯一对应一个数据库表的一行(一对一关系)。...自定义外键: return $this->hasOne(Profile::class,'显示指定自定义外键'); 2.4 一对一测试 依赖注入Request $request,获取当前登录用户$request...五、多样化的一对多关系映射(多态关联) 面向对象多态:运行时加载机制 ? 更多:https://laravel-china.org/doc... 伪造数据: ? ?...六、多对多多态关联 除了传统的多态关联,您也可以定义「多对多」的多态关联。例如,Post 模型和 Video 模型可以共享一个多态关联至 Tag 模型。...使用多对多多态关联可以让您在文章和视频中共享唯一的标签列表。 更多:https://laravel-china.org/doc...

    1.9K30

    60秒问答:多态和函数重载的关系?

    目录:阅读该文章将获得如下收益 什么是多态,与重载,重写,隐藏什么关系?...函数重载与stl萃取机制结合 实现编译时多态 汇编查看虚函数指针与构造 和析构函数关系。 60秒问答 一、 问:重载,重写 ,隐藏区别? 答: 重载 相同作用域内,函数名字相同,参数不同。...整理这个文章之后,依然不清楚,有了解的可以告诉我 我知道的 面向对象的三大特征: 1.封装:保证对象自身数据的完整性、安全性 2.继承:建立类之间的关系,实现代码复用、方便系统的扩展 3.多态:相同的方法调用可实现不同的实现方式...从实现的角度来讲,c++多态性可以划分为两类 编译时的多态:函数重载和运算符重载,在编译时就决定调用哪个函数 重载 编译时的多态 重载指允许【在相同作用域中】存在多个同名的函数,这些函数的参数表不同 运行时的多态...二、我不清楚的:重载 参数不一样呀? 2.1 疑问 多态:相同的方法调用可实现不同的实现方式,定义 重载 参数不一样呀?怎么算 多态分为四种:重载多态、强制多态、包含多态和参数多态。

    1.4K10

    Elixir and Pylons 中多态继承和自关联关系的创建

    我们知道,在Elixir和Pylons中,多态继承和自关联关系是两个独立的概念,分别用于处理不同的情况。...而在Pylons中,多态继承通常由SQLAlchemy提供的 polymorphic 关系来实现。下面分别介绍在Elixir和Pylons中如何创建多态继承和自关联关系。...一、问题背景一位初学者在 Elixir 和 Pylons 中创建一个 Wiki 项目,并按照 Pylons 文档中的示例重写了 Wiki 的数据库架构。...Employee 模型通过 manager_id 外键和 relationship 关联实现了自关联关系,表示员工与其直接下属之间的关系。...这里需要注意的是,上述示例仅提供了基本的概念,实际应用中可能需要我们根据具体需求进行更复杂的模型定义和关联设置。希望这篇技术文章对您有所帮助。

    12610

    Laravel 5.5 的自定义验证对象类

    Laravel 5.5 将提供一个全新的自定义验证规则的对象,以作为原来的 Validator::extend 方法的替代。...Laravel 中的表单验证是比较方便的,而且内置了大量的可用验证规则,但不管官方提供了多少,总还是会有满足不了需求的时候。...但在 Laravel 5.5 版本中,我们有了新的手段,只要定义一个实现 Illuminate\Contracts\Validation\Rule 接口的类即可实现自定义的验证规则,并可以直接使用。...ImplicitRule { ... } 采用 Laravel 5.5 新增的自定义验证类,可以更好地管理大量的自定义验证规则,而且在 PHPStorm 之类的 IDE 中,从验证代码里快速跳转到对应的验证类的代码也会更方便...你可以查看该功能在 Laravel 框架的 github 上的 Pull Request,阅读具体的实现代码以及相关的测试代码。

    3K90

    Laravel学习记录--Model

    - 多态一对 - 多态一对多 - 多态多对 关联查询 继承:ILLuminate\Database\Eloquent\Model model与表名的关系 表名去掉...Laravel 自带的 软删除功能 就利用全局作用域从数据库中提取「未删除」的模型。编写自定义的全局作用域可以提供一个方便、简单的方法来确保给定模型的每个查询都受到一定的约束。...Laravel中允许你自定义中间表模型,需要注意的是中间表模型与普通模型不一样 普通模型继承自Illuminate\Database\Eloquent\Model,而中间表模型继承自Illuminate...学习了一对一多态关联,一对多多态关联相对简单,实际上原理跟一对一多态差不多,只是这里变成了一对多而已 下面举例说明,以评论来说,文章跟评论的关系是一对多,可能我们的系统里面 还会针对某个模块设置评论窗口...$related:反关联模型类 $name:关联关系的名称 $type:根据关联名称拼接存放关联类的字段,也可自定义 $id:根据关联名称拼接存放关联类的id .也可自定义 $localKey:当前模型的主键

    13.6K20

    mysql-外键的三种关系

    介绍 因为有foreign key的约束,使得两张表形成了三种了关系: 多对一 多对多 一对一 重点理解如果找出两张表之间的关系 分析步骤: #1、先站在左表的角度去找 是否左表的多条记录可以对应右表的一条记录...,即多对多,需要定义一个这两张表的关系表来专门存放二者的 关系 #一对一: 如果1和2都不成立,而是左表的一条记录唯一对应右表的一条记录,反之亦然。...这种情况很简单,就是在左表foreign key右 表的基础上,将左表的外键字段设置成unique即可 表的三种关系 (1)书和出版社   一对多(或多对一):一个出版社可以出版多本书。...创建被关联表author表,之前的book表在讲多对一的关系已创建 mysql> create table author(id int primary key auto_increment,name varchar...(20)); Query OK, 0 rows affected (0.09 sec) 这张表就存放了author表和book表的关系,即查询二者的关系查这表就可以了 mysql> create table

    78430

    Php Laravel框架 多表关系处理 之 Eloquent一对多关系处理

    Php Laravel框架 多表关系处理 之 Eloquent一对多关系处理 本博文主要介绍 Laravel 框架中 Eloquent 对一对多关系的处理以及在 Laravel Administrator...Laravel 提供了四种类型的关系: –一对一 –一对多 –多对多 – 多态关系 一对多 一个一对多关系的样例是一篇博客文章有很多评论或者一个课程有的多次分数信息等。...public $timestamps = false; /* * 分数表(ScoreInfo)与课程表(SobjectInfo)、学生信息表(StuInfo)有主外键关系...> 通过以上步骤的处理。表与表之间的一对多关系已确立, 以下将介绍在Laravel Administrato 后台中的实现 下拉列表查询、绑定等应用 的表中,但因为我们之前在 Model中已建立了它们之间的 一对多关系,因此我们能够自由搭配组合 效果图例如以下: 10个Laravel4

    2.1K40

    django模型中有外键关系的表删除相关设置

    0904自我总结 django模型中有外键关系的表删除相关设置 一.一对一 例如有Author、AuthorDetail两表 author = models.OneToOneField(to='Author...Book表中(多的一方):出版社删除书外键不动,书删除没有任何影响 2)出版社找书用 外键related_name(books),书找出版社 外键字段(publish) 3)db_constraint..., models.CASCAD为级联关系,'SET_NULL'置空,SET_DEFAULT设为默认值 两者区别 models.SET关联表内容删了,关联的相关内容不会删除 models.CASCAD关联表内容删了...,关联的相关内容会删除 db_constraint关系断开后,但是不影响联表查询 四.多对多关系 例如Book、Author两表 authors = models.ManyToManyField(to=...:出版社删除或书删除彼此不影响,但关系表一定级联删除 2)正向找 外键字段,反向找 外键字段related_name 3)db_constraint断开表关联,on_delete不存在(不设置,本质在第三张表中设置

    3K20

    Laravel Eloquent 模型关联关系(下)

    关联查询 关于关联查询,我们在前面介绍关联关系定义的时候已经穿插着介绍过,这里简单回顾下。...如果是要更新新创建的模型实例所属模型(父模型)的外键字段,比如以 posts 表为例,新增的记录想要更新 user_id 字段,可以这么实现: $user = User::findOrFail(1);...空对象模型 如果外键字段 user_id 允许为空的话,当我们访问 Post 模型上的 author 属性时,默认返回为 null。...: 结语 好了,关于关联关系我们就介绍到这里,我们分了三篇的篇幅来介绍 Eloquent 模型的管理关系,回顾一下,主要包含以下内容: 七种关联关系的定义:一对一、一对多、多对多、远层一对多、一对一的多态关联...、一对多的多态关联、多对多的多态关联; 以上关联关系的查询,主要包含两种方式:懒惰式加载和渴求式加载; 基于关联查询构架复杂查询对查询结果进行过滤; 关联模型的更新、插入和删除操作。

    19.6K30

    当HashMap的键遇见自定义类型时

    1 概述 这是Java中经典的问题,在面试中也经常被问起.很多书提到要重载hashCode()和equals()两个方法才能实现自定义键在HashMap中的查找,但是为什么要这样以及如果不这样做会产生什么后果...,好像很少有文章讲到,所以来这一篇记录下. 2 案例分析 首先,如果我们直接用以下的Person类作为键,存入HashMap中,会发生发生什么呢?...的两个键值对,并且它们的key值还是不相同的,这显然是错误的; 在获取value值时,我们分别用三个Person对象去查找,这三个对象和我们刚刚存入的三个key值(在期望中)是相同的,但是查找出的却是三个...而在Object类中Hash Code默认是使用对象的地址计算的,那两个Person(“003”)的对象地址是不同的,所以它们的Hash Code也不同,自然HashMap也不会把它们当成是同一个key...就是因为避免出现上述例子中的出现的情况,因为根据对Person类的hashCode()方法的重载实现,Person类会直接用id这个String类型成员的Hash Code值作为自己的Hash Code

    40530

    orm 系列 之 Eloquent演化历程2

    ,也是laravel中一大亮点Artisan,Artisan是 Laravel 自带的命令行接口名称,此处不做具体的介绍了,有机会再细说的,当我们在命令行中执行php artisan command的时候...:包含了最基本的Sql的操作和语法逻辑,类似于自定义了一个DSL语言,提供了面向对象的操作方式 Schema:这也是本篇讲migrations or database modification logic...本文最后讲下Eloquent中新增的对象之间的关系:多态关系,以下内容摘自[ Laravel 5.3 文档 ] Eloquent ORM —— 关联关系 表结构 多态关联允许一个模型在单个关联下属于多个不同模型...例如,假设应用用户既可以对文章进行评论也可以对视频进行评论,使用多态关联,你可以在这两种场景下使用单个comments表,首先,让我们看看构建这种关联关系需要的表结构: posts id - integer...参考 [ Laravel 5.3 文档 ] Eloquent ORM —— 关联关系

    2.4K30
    领券