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

laravel 5.4多态关系-通过查询作用域进行急切读取

Laravel是一种流行的PHP开发框架,它提供了丰富的功能和工具,使开发人员能够快速构建高质量的Web应用程序。在Laravel中,多态关系是一种关系类型,它允许一个模型在关联中可以属于多个不同的模型。

通过查询作用域进行急切读取是指在使用多态关系时,通过定义查询作用域来优化查询性能,以减少数据库查询次数并提高应用程序的响应速度。

具体来说,当我们在Laravel中定义多态关系时,可以使用morphTo方法指定多态关联的模型和关联字段。然后,我们可以使用with方法和查询作用域来进行急切读取,以一次性获取所有相关模型的数据,而不是每次访问关联时都进行数据库查询。

以下是一个示例代码,演示了如何在Laravel 5.4中使用多态关系和查询作用域进行急切读取:

代码语言:php
复制
// 定义多态关系
class Comment extends Model
{
    public function commentable()
    {
        return $this->morphTo();
    }
}

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

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

// 定义查询作用域
class CommentScope
{
    public function scopeWithRelations($query)
    {
        return $query->with('commentable');
    }
}

// 使用查询作用域进行急切读取
$comments = Comment::with(['commentable' => function ($query) {
    $query->withRelations();
}])->get();

foreach ($comments as $comment) {
    echo $comment->commentable->title;
}

在上面的示例中,我们定义了一个多态关系,其中Comment模型可以属于Post模型或Video模型。然后,我们定义了一个查询作用域CommentScope,其中的scopeWithRelations方法用于进行急切读取。最后,在获取评论数据时,我们使用with方法和查询作用域来一次性获取所有相关模型的数据。

多态关系的优势在于可以简化数据模型的设计,使得模型之间的关联更加灵活和可扩展。它适用于各种场景,例如博客文章和评论、商品和评价等。

对于腾讯云相关产品和产品介绍链接地址,由于要求不能提及具体的云计算品牌商,我无法给出具体的推荐链接。但是,腾讯云作为一家知名的云计算服务提供商,提供了丰富的云计算产品和解决方案,可以根据具体需求选择适合的产品和服务。

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

相关·内容

在 Laravel Eloquent 模型类中使用作用域进行查询

问题引出 在通过 Eloquent 模型实现增删改查这篇教程中,我们已经学习了如何在 Eloquent 模型类中进行各种查询,但是这些查询大多需要手动调用查询构建器提供的各种方法来实现。...接下来,我们就来演示如何在 Eloquent 模型类上使用「作用域」进行查询。...这样,当我们通过 User 模型类进行查询的时候,就会自动应用全局作用域指定的查询条件了,以 User::all() 为例,我们通过 Telescope 的 「Queries」 页面就能看到对应的 SQL...动态作用域 此外,Eloquent 模型类还支持「动态作用域」,所谓动态作用域指的是在查询过程中动态设置预置过滤器的查询条件,动态作用域和局部作用域类似,过滤器方法名同样以 scope 开头,只不过可以通过额外参数指定查询条件...`deleted_at` is null 动态作用域的调用和移除方式和局部作用域一样。 本系列教程首发在Laravel学院(laravelacademy.org)

2.5K20

Laravel学习记录--Model

Model类 app/ Model添加 Model查询 Model更新 Model删除 Model约定 查询全局作用域 查询本地作用域 Model关联 一对一 一对多 远程一对多 渴求式加载 多对多...多态关联 - 多态一对 - 多态一对多 - 多态多对 关联查询 继承:ILLuminate\Database\Eloquent\Model model与表名的关系...Laravel 自带的 软删除功能 就利用全局作用域从数据库中提取「未删除」的模型。编写自定义的全局作用域可以提供一个方便、简单的方法来确保给定模型的每个查询都受到一定的约束。...Laravel中Eloquent还支持动态作用域,动态作用域指在查询过程中动态设置预置过滤器的查询条件,动态作用域与本地作用域类似,都是以scope作为前缀,调用方法也相同,不同的是动态作用域可以通过额外参数指定查询条件...','>',$price) } 在查询时直接调用 $goods = Good::Price(200)->get(); 全局作用域可理解为限制约束,本地作用域/动态作用域则可理解为一些定义好的常用约束集合

13.6K20
  • laravel-nestedset:多级无限分类正确姿势

    一致性检查和修复 作用域 Nested Sets Model简介 Nested Set Model 是一种实现有序树的高明的方法,它快速且不需要递归查询,例如不管树有多少层,你可以仅使用一条查询来获取某个节点下的所有的后代...嵌套集合模型 安装要求 PHP>=5.4 laravel>=4.1 v4.3版本以后支持Laravel-5.5 v4版本支持Laravel-5.2、5.3、5.4 v3版本支持Laravel-5.1 v2...parent_id字段的继承信息,给每个node设置合适的lft 和 rgt值 Node::fixTree(); 作用域(scope) 假设你有个Memu模型和MenuItems.他们之间是one-to-many...protected function getScopeAttributes() { return [ 'menu_id' ]; } 现在我们为了实现自定义的查询,我们需要提供需要限制作用域的属性...node,scope自动基于设置的限制作用域属性来删选node。

    3.5K20

    Laravel框架关键技术解析

    ()方法进行自动加载 在Laravel架构中,通过函数spl_autoload_register实现类自动加载函数的注册,其中类的自动加载函数队列中包含了两个类的自动加载函数,一个是composer生成的基于...(callback)参数的值 2.匿名函数既可以作为参数传递给函数,也可以做为变量赋值,进而控制函数的执行过程;可以从父作用域中继承变量,使用use关键字来继承;默认PHP是通过复制的方式传入上层变量进入匿名函数...3.Laravel框架中的应用:大量使用,如在服务提供者注册过程中,通过将服务名称与提供服务的匿名函数进行绑定,在使用时可以实现动态服务解析。...控制反转是将组件间的依赖关系从程序内部提到外部容器来管理,而依赖注入是指组件依赖通过外部以参数或其他形式注入,两种说法本质上是一个意思 5.Laravel中:Illuminate\Container\Container...中的App外观解析 9.Laravel框架还实现了一种依赖注入的方式进行服务解析,服务名称必须为服务生成的实例对象的类名称或接口名称,通过服务容器创建的类的构造函数可以通过依赖注入的方式解决依赖问题,对于方法也是一样

    12K20

    nextline函数_Java 中nextLine()方法没有执行直接跳过解决办法

    原来nextLine()函数获取的是一整行的内容其中也包括了(\n)也就是换行符 而nextInt()函数获取的仅仅是一个值不包含(\n), 那么nextInt()后面的nextLine()读取一行,...就把(\n)读进去了,意思就是nextLine()的值是(\n),所以不会进行数据获取。...改了之后程序正常输入: [03]java中的方法以及控制语句 00 Java中的语句块 语句块(有时叫做复合语句),是用花括号扩起的任意数量的简单Java语句.块确定了局部变量的作用域...多态是面向对象编程中最为重要的概念之一,而覆盖又是体现多态最重要的方面.对于像c#和java这样的面向对象编程的语言来说,实现了在编译时只检查接口是否具备,而不需关心最终的实现,即最终的实 … Java...The non-mobile stuff is here (hint: you get jerk … mybatis随意sql语句 mybatis的mapper.xml随意sql语句, 不管表之间存不存在关系

    1.1K20

    SqlAlchemy 2.0 中文文档(十六)

    特定子类进行 SELECT 构建在连接继承层次结构中的类上的 SELECT 语句将针对将类映射到的表以及任何现有的超级表进行查询,并使用 JOIN 将它们链接在一起。...,其中它们隐式地表示多态查询中的连接表。...在下面的示例中,我们演示了从父实体Company沿着一对多关系Company.employees进行连接,该关系在 setup 中配置为链接到Employee对象,使用一个with_polymorphic...”时,查询还可以直接引用子类实体,在这里它们隐式地代表了多态查询中的联接表。...在下面的示例中,我们说明了从父Company实体沿着一对多关系Company.employees进行连接,该关系在 setup 中配置为链接到Employee对象,使用with_polymorphic(

    28410

    orm 系列 之 Eloquent演化历程2

    我们通过一个比较有意思的命令Make来看下migration的实现,make的作用是新建一个migration文件,其会根据命令函数参数,去读取src/Illuminate/Database/Migrations...本文最后讲下Eloquent中新增的对象之间的关系:多态关系,以下内容摘自[ Laravel 5.3 文档 ] Eloquent ORM —— 关联关系 表结构 多态关联允许一个模型在单个关联下属于多个不同模型...例如,假设应用用户既可以对文章进行评论也可以对视频进行评论,使用多态关联,你可以在这两种场景下使用单个comments表,首先,让我们看看构建这种关联关系需要的表结构: posts id - integer...第一步addConnection,添加了默认的数据库配置,通过这个配置,我们可以通过DatabaseManager.connection来获取数据库连接connection,从而进行操作。...参考 [ Laravel 5.3 文档 ] Eloquent ORM —— 关联关系

    2.4K30

    3分钟短文:Laravel 从软删除说到模型作用域的概念

    我们从软删除的使用,再顺便说一说模型内的作用域的概念。 代码时间 常规的删除操作分两步进行,一步是把数据从数据库中查询出来,使用laravel模型的方法, 则返回的是一个模型对象。...::destroy(1); 该方法可以可以用于批量删除传入的指定ID数组的条目: Contact::destroy([1, 5, 7]); 当然了,delete方法只是链式调用的一个方法,我们通过查询构造器过滤后的数据集...既然说到了模型作用域,我们不妨延伸一下,说说这个设计点,以及适用的场景。 比如说有一个查询条件在代码内到处都要用,有没有简写方法,写一次其他地方可以随意调用呢?这就是本地作用域的方法了。...如果是想软删除条目那样,默认把所有的查询都追加 自定义的查询条件,就需要我们上面说的全局作用域了。...写在最后 本文从laravel模型的写操作删除动作,讲到了软删除的概念。进而引申出来本地作用域和全局作用域的使用。软删除几乎贯穿了我们应用的始终,需要大家勤学苦练。

    1.4K30

    Laravel Eloquent 模型关联关系(下)

    在前面两篇教程中,学院君陆续给大家介绍了 Eloquent 模型类支持的七种关联关系,通过底层提供的关联方法,我们可以快速实现模型间的关联,并且进行关联查询。...另外,如果访问的是模型实例上的 author() 方法时,返回的不是用户实例了,而是一个关联关系实例,该实例注入了查询构建器,所以你可以在其基础上通过方法链的方式构建查询构建器进行更加复杂的查询,我们以一个一对多的查询为例...; 渴求式加载会在查询到模型实例结果后,通过 IN 查询获取关联结果,并将其附着到对应的模型实例上,在后面访问的时候不会再对数据库进行查询。...,我们分了三篇的篇幅来介绍 Eloquent 模型的管理关系,回顾一下,主要包含以下内容: 七种关联关系的定义:一对一、一对多、多对多、远层一对多、一对一的多态关联、一对多的多态关联、多对多的多态关联;...以上关联关系的查询,主要包含两种方式:懒惰式加载和渴求式加载; 基于关联查询构架复杂查询对查询结果进行过滤; 关联模型的更新、插入和删除操作。

    19.6K30

    Laravel 7 新特性-路由的趟坑之路(自定义键名以及作用域)

    Laravel 7 开始新增了一些新特性,今天我们来讲解下 路由绑定的新用法,自定义键名(slug)以及作用域(范围限定) 首先我们 安装最新版本的 Laravel ,并且创建两张数据表。...我们的以前的 URL 可能是如下这样: http://laravel7.test/posts/posts/1 我们是通过主键 ID 来进行查找的。...public function getRouteKeyName() { return 'slug'; } 接下来我们就可以使用 slug 来进行查询了 比如下面的 URL http://laravel7...Route::get('posts/{post:slug}', function (\App\Post $post) { dd($post); }); 作用域(访问限制) 怎么理解呢?...转载无需与我联系,但须注明出处,注明文章来源 Laravel 7 新特性-路由的趟坑之路(自定义键名以及作用域) 联系我 hedeqiang.png

    2.5K10

    PHP程序员:你过来,给我说说 $this,self,static 有什么区别?

    而诸如 Zend Symfony Laravel 框架出现,参与开发的人数众多,设计模式非常巧妙,让很多优秀的开发者把精力投入到 PHP 的 OOP 化。...下面使用含有 $this 对象属性/方法调用重载了的函数方法,演示类的多态性: ? 上述文件执行后,返回值 Y::foo()。$this 作为实例化的 Y 对象,直接访问了其动态方法 foo()。...引申:尽量别用 self::,要用 static:: self 简单好用,但是作用域叫人恼火。因为它的作用域是在定义时的,而不是执行时的。比如这么个例子: ?...这是由 self 作用域决定的。 怎么才能返回期望的值?使用 static 替换 self。 还是那个规则:$this 引用的是当前的类的实例,static 引用的是当前的类本身。...下面是 Laravel ValidationData 类内的一个静态方法。 ? 写在最后 本文通过几个简单的小栗子,说明了 $this self static 之间的微妙差别,以及作用区间。

    1.1K20

    PHP面试题集锦

    其作用简单来讲就是利用依赖关系注入的方式,把复杂的应用程序分解为互相合作的对象,从而降低解决问题的复杂度,实现应用程序代码的低耦合、高扩展。...(4)数据传输上:get 方式通过url地址栏拼接参数进行传输,post 方式通过body体进行传输。...3、多态性:子类继承了来自父级类中的属性和方法,并对其中部分方法进行重写。于是多个子类中虽然都具有同一个方法,但是这些子类实例化的对象调用这些相同的方法后却可以获得完全不同的结果,这种技术就是多态性。...(提高mysq执行效率和查询速度) (5)使用nginx做负载均衡。(将访问压力平均分配到多态服务器) 请说明php.ini中的safe_mode开启之后影响了哪些函数?...static 静态方法,是类的成员方法,但不需要实例化类可直接使用 GLOBAL 在函数内使用具有全局作用域的变量,如GLOBAL[‘a’] 单例模式使用场景有哪些?

    6.9K20

    3分钟短文:Laravel slug,让你的url地址更“好记”

    如果你有印象的话,应该会记得laravel模型的find等方法,是基于primary key进行索引,以便加快查询速度。拿到模型的ID,查询该条目数据,然后返回模型实例。...Event extends Model { use Sluggable, SluggableScopeHelpers; } 从名字你就能猜测的到,SluggableScopeHelpers 是一个全局作用域文件...完成引入后,在使用模型进行查询时,就可以这样使用了: $event = Event::findBySlug('laravel-hacking-and-coffee'); $event = Event::...findBySlugOrFail('laravel-hacking-and-coffee'); 归根结底,就是使用slug字段记录查询的字符串,而slug字段在对应关系中定义为 source => ‘name...写在最后 本文介绍了在模型文件内,引入slug的功能,并通过修改模型的查询方式,让模型的默认查询方式修改为通过字符串进行查询,从而可以在路由文件内构造更友好的查询url。

    3.5K11

    php基础(一)

    static 静态方法,是类的成员方法,但不需要实例化类可直接使用 $GLOBAL 在函数内使用具有全局作用域的变量,如$GLOBAL['a'] 2.子类重写父类的 protected 方法有什么限制?...php-fpm,FastCGI,Nginx 之间是什么关系?...CGI,通用网关接口,用于WEB服务器和应用程序间的交互,定义输入输出规范,用户的请求通过WEB服务器转发给FastCGI进程,FastCGI进程再调用应用程序进行处理,如php解析器,应用程序的处理结果如...$(document).ready()函数作用域是什么? 形成闭包,起到隔离作用域的作用。...JSONP 的原理 AJAX 无法跨域是受到“同源政策”的限制,但是带有src属性的标签(例如、、)是不受该政策限制的,因此我们可以通过向页面中动态添加<script

    2.1K20

    从0开始做一个审批模块

    具体的需求场景 •允许用户申请加入团队或者项目•申请之后系统推送审批通知给对应的管理员•管理员可以对申请进行审批:通过或者拒绝•审批通过则申请者顺利加入团队/项目中,否则申请无效•审批结果推送给管理员以及申请者...所以这个需求方,可以定义为多态的,说的通俗一点就是通过类型和 ID 来决定对象。不过这里我并没有定义为多态,因为应用里面不会出现需求方不确定类型的场景,还是继续沿用 creator_id。...下面的示例代码将以 PHP 语言进行编写,使用的框架为 Laravel[2]。 建立模型类 根据上面设计好的数据表,我们对 Apply 进行建模: Laravel 中多态关系的表单验证[3]』 。...[2] Laravel: https://laravel.com/ [3] Laravel 中多态关系的表单验证: https://learnku.com/articles/12449/form-validation-of-polymorphic-relationships-in-laravel

    1.7K10

    面试的角度诠释Java工程师(一)

    什么是多态? ①多态就是对象拥有多种形态:引用多态和方法多态。 ②引用多态:父类的引用可以指向本类对象、父类的引用可以指向子类的对象。...③方法多态:创建本类对象时,调用的方法为本类的方法;创建子类对象时,调用的方法为子类重写的方法或者继承的方法。 ④存在多态的必要条件:继承、重写。 ⑤多态的作用是消除类型之间的耦合关系。...②SELECT column1 FROM t2 称为子查询。 所以,我们就说子查询是嵌套在外查询内部的。而事实上它也有可能在子查询内部再嵌套一个或者多个子查询。...同时它也是HttpServletRequest类的实例,并且具有请求域,也就是在完成客户端的请求之前,该对象是一直有效的。...和request一样,它具有页面的作用域,也就是在访问一个页面的时候,该页面的response对象只对这次访问有效,往后执行是不存在、无效的。

    53410

    3分钟短文|Laravel 使用like匹配字符串的用法示例

    引言 本文接着laravel的功能讲解,说一说在模型中查询条件内,使用like这样的SQL关键字 进行子字符串匹配。并通过几个示例,和不同的实现方法,为大家展示laravel的灵活性。...如果实在不行,在可读性上,我们可以尝试一下laravel提供的本地作用域功能, 在模型内,或者全局内创建一个查询方法。...', $name)->get(); 把查询语句单独拿出来封装为公用的方法,使程序更加简洁易用。..., [$request->email,"%{$request->name}%"])->get(); 特别注意的是laravel的参数绑定是使用问号的。...最后再说一个知识点,就是MySQL内置的关键字,除了like匹配之外,我们还可以使用内置字符串函数instr进行判断。

    2.1K10
    领券