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

自定义键的Laravel多态关系

是指在Laravel框架中,通过使用多态关系来建立不同模型之间的关联,并且可以自定义关联键的名称。

多态关系是指一个模型可以与多个其他模型建立关联,而不需要为每个关联都创建一个独立的关联方法。这种关系在实际开发中非常常见,例如一个评论模型可以与文章模型和视频模型建立关联。

在Laravel中,多态关系通过使用morph系列方法来实现。具体而言,可以使用morphTo方法在多态关系的"多"端定义关联,使用morphMany或morphOne方法在"一"端定义关联。

自定义键是指可以自定义关联键的名称,而不是使用默认的命名规则。默认情况下,Laravel会根据模型名称和关联类型来生成关联键的名称,但是在某些情况下,我们可能希望使用不同的名称来表示关联。

举例来说,假设我们有一个评论模型Comment,它可以与多个模型(如文章和视频)建立多态关系。默认情况下,Laravel会使用commentable_id和commentable_type作为关联键的名称,其中commentable_id表示关联模型的ID,commentable_type表示关联模型的类型。

但是,如果我们希望使用不同的关联键名称,可以在定义关联时使用withPivot方法来自定义键。例如,我们可以使用以下代码来定义评论模型与文章模型的多态关系,并自定义关联键名称为post_id和post_type:

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

在上述代码中,我们使用morphTo方法定义了与文章模型的多态关系,并通过withPivot方法指定了自定义的关联键名称。

使用自定义键的Laravel多态关系可以提供更灵活的关联方式,并且可以根据实际需求来定义关联键的名称,以适应不同的业务场景。

腾讯云相关产品和产品介绍链接地址:

  • 腾讯云服务器(CVM):https://cloud.tencent.com/product/cvm
  • 腾讯云数据库(TencentDB):https://cloud.tencent.com/product/cdb
  • 腾讯云对象存储(COS):https://cloud.tencent.com/product/cos
  • 腾讯云人工智能(AI):https://cloud.tencent.com/product/ai
  • 腾讯云物联网(IoT):https://cloud.tencent.com/product/iotexplorer
  • 腾讯云区块链(BCS):https://cloud.tencent.com/product/bcs
  • 腾讯云元宇宙(Metaverse):https://cloud.tencent.com/product/metaverse
页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

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...)) 如果我们给 ID 为 1 文章打上两个标签,数据库标签关系存储结果就是这样子: select * from taggables; +--------+-------------+---...思路来源 我尝试跟踪了一遍源码,发现模型中有一个方法 getMorphClass ,多态关联时候,就是用它来取目标对象类型名称,默认返回类名: public function getMorphClass...》 我们目标是使用表名来做为关系类别名,那么在模型中如何获取表名呢,直接使用模型 getTable 即可,那么整个 trait 实现如下: app/Traits/UseTableNameAsMorphClass.php...总结 以上所述是小编给大家介绍Laravel设置多态关系模型别名方式,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家。在此也非常感谢大家对ZaLou.Cn网站支持!

2K21
  • 一种 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

    laravel ORM关联关系 with和whereHas用法

    with 渴求式预加载 可以有效避免 N+1 问题,用法如下: $books = App\Book::with('author')- get(); 如果有多个关联关系可以用“,”隔开,还可以使用闭包来对关联关系进行限制...),没有筛选功能 with 更像 sql 中 join,就是你存不存都有执行,存在结果不为空,存在关联结果,不存在结果为空,关联结果为空 whereHas 查询存在关联关系,还有对应 whereDoesntHave...,查询不存在关联关系,像下面这样: // 获取发布文章标题中有first用户 $users= User::whereHas('posts', function ($query) { $query...,适合查找 存在不存在 感觉 with 更多用在查看详情时候,你想知道你查看对象具体信息,关联到内容是怎样, 而 whereHas 更多用在筛选,你要把符合条件关联关系对象给他找出来。...这就是我对 with 和 whereHas 一些理解了 以上这篇laravel ORM关联关系 with和whereHas用法就是小编分享给大家全部内容了,希望能给大家一个参考。

    4K31

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

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

    12410

    laravel5.6中约束示例

    场景 如果现在有两张表,一张表是文章表articles,一张表是分类表categories,其中在文章表中有一个分类字段category_id,现在想在删除分类表中某一分类时,该分类下所有文章也一起被删除...,那么这时候就可以用到外约束 具体用法如下: 给文章表添加外约束 $table- unsignedInteger('category_id')- comment('文章所属分类|select');...$table- foreign('category_id')- references('id')- on('categories')- onDelete('cascade'); 其中需要注意是分类表categories...中主键字段id与文章表articles中字段category_id数据类型或者是数据长度要保持一致,因为作为主键id值是从1开始自增,所以在被其绑定字段数据类型就不能使用integer...,而要改用unsignedInteger 以上这篇laravel5.6中约束示例就是小编分享给大家全部内容了,希望能给大家一个参考。

    1.7K31

    Laravel学习记录--Model

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

    13.6K20

    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

    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

    78330

    浅谈laravel orm 中一对多关系 hasMany

    个人对于laravel orm 中对于一对多关系理解 文章表 article,文章自然可以评论,表 comment 记录文章评论,文章和评论关系就是一对多,一篇文章可以有多个评论。...在 comment 表中有字段article 记录评论所属文章,文章和评论关系如下: article:id … … comment : id … … article_id 在 comment 表中有关联...article article_id,所以在 Comment 模型中是 belongsTo方法,在 Article 模型中是hasMany方法 在文章模型 Article 中,则可以有如下方法来关联评论...'(这里是关联外字段名,这个例子就是 article_id 字段), ‘id'(对应关联模型主键,这里 id 是关联 article 表id)); } 对应在 Comment 模型中,则可以有如下方法来关联文章...'(这里是关联外字段名,这个例子就是 article_id 字段), ‘id'(对应关联模型主键,这里 id 是关联 article 表id)); } 以上这篇浅谈laravel orm 中一对多关系

    1.9K31
    领券