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

Laravel 多态关系表单验证

相信大家使用 Laravel 开发应用时候都会有评论模块吧,而且我们通常将该模块设计为多态关系(如果你对这个关系还不明白的话,请赶紧打开 Laravel 文档数据库关系章节复习一遍吧!)。...一般来讲有两种方式,而我们通常用一种是从父模型使用关系写入,比如我们有一个 App\Thread 类,它里面对评论关系是这样: class Thread {    public function...comments() {            $this->morphToMany(Comment::class, 'commentable');    } } 然后我们写入评论时通常是这样..., ]); 其实不管哪一种,我们都少不了表单验证,而且无论使用任何一种我们都得需要传入两个关键参数: 类型与 id,那就涉及到一个问题,如何验证呢?...是不是简单很多,而且这样验证规则还能重用在其它同类多态关系地方哦。 这样就结束了么?没有! 我们上面的拓展验证规则写法没有感觉有些粗暴么?是时候规范一下了。

2.1K40
您找到你想要的搜索结果了吗?
是的
没有找到

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用法就是小编分享给大家全部内容了,希望能给大家一个参考。

3.8K31

详解Laravel设置多态关系模型别名方式

作为 Laravel 重度使用者肯定都对多态关系不默生,以官方文档为例,文章有标签,视频有标签,那么文章和视频这些模型与标签模型关系就是 多态多对多(Many To Many (Polymorphic...)) 如果我们给 ID 为 1 文章打上两个标签,数据库标签关系存储结果就是这样子: select * from taggables; +--------+-------------+---...\Post', 'videos' = 'App\Video', ]); https://laravel.com/docs/6.x/eloquent-relationships#custom-polymorphic-types...》 我们目标是使用表名来做为关系类别名,那么在模型中如何获取表名呢,直接使用模型 getTable 即可,那么整个 trait 实现如下: app/Traits/UseTableNameAsMorphClass.php...总结 以上所述是小编给大家介绍Laravel设置多态关系模型别名方式,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家。在此也非常感谢大家对ZaLou.Cn网站支持!

1.9K21

如何计算文本非重复计数

需求:计算快递单号非重复计数 ? (一) 需求分析 如果要计算非重复计数,我们很容易可以想到一个函数DistinctCount,那如果直接使用是不是就可以了呢?...这里会有几个问题: 空值未进行处理 总计这里多计了1,而且在未有单号情况下也作为了1显示。 那我们来了解下原因,空值的话如何处理以及为什么总计这里会多了1。...因为DistinctCount在计算非重复计数时候会把空值也作为一个值来进行计算,所以导致数据上差异。...但是和我们要求数据透视表有些许差异,结果是要求把订单号全部显示出来,而直接拖入字段后把没有快递单号订单号给隐藏了。这里留个小悬念,可以自己动手实现下这个功能。...如果觉得有帮助,那麻烦您进行转发,让更多的人能够提高自身工作效率。

1.6K10

浅谈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.8K31

具有嵌套关系可重用API资源——Laravel5.5

本文内容主要围绕在 Laravel 5.5 中使用 API 开发重要步骤,着重介绍如何利用 Laravel API 资源(Resource)和控制器(Controller)进行多因素身份验证(MFA...注:本文受到Laravel创始人Taylor Otwell介绍使用 Laravel5.5 开发API时如何替换 Fractal 启发。 1....简单来说,这意味着资源类中可以直接使用 $this->attributeName 方式访问模型中属性,而不必每次都通过模型实例去获取属性。...简化和逐步进行本文着重于学习如何使用 Resource::collection 而不是手动实例化类,并将关系数据提供(或不提供)责任委托给控制器。...总体而言,本文聚焦于利用 Laravel Resource::collection,并强调控制器对于处理数据关系包含重要性。

11310

如何优雅计数据导出功能?

对于一些报表性后台,有些会提供数据导出功能。如果查询维度过多又都是耗时操作,那就像是开了潘多拉盒子,会造成比较恶劣后果。 数据导出,下载,是和产品定位息息相关。...二、文件 数据导出下载,一般都会合并多页请求,这个普通展示是不一样。生成文件过程,不要放在内存中。尤其对于并发性有些规模,或者结果集很大。...用户需要这些数据时,可以直接进入下载列表直接获取。 三、排队 排队主要是资源限制。可以有全局排队和单机排队只说。简单方案,就是单机排队,负载均衡有外围nginx进行负责。...处理进程会根据系统负载情况,获取一定任务进行执行。有了这个队列,我们就能干很多事情。 1、可以对资源利用进行控制,不至于并行处理多个大请求 2、防重入,一样参数和范围,不予处理。...具体在产品设计上,也要这样考虑: 1、查询纬度不需要事无巨细,如果下载条件有父子关系,占用资源相差无几,则只提供父类下载即可。客户下载后,自行excel过滤。

1.9K31
领券