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

Laravel Eloquent 模型关联关系(下)

查询语句如下: 如果你想进一步过滤出文章标题和评论都包含「Laravel学院」的用户,可以在上述闭包函数中通过查询构建器进一步指定: $users = User::whereHas('posts',...统计关联模型 我们还可以通过 Eloquent 提供的 withCount 方法在不加载关联模型的情况下统计关联结果的数量。...此外,你还可以通过数组传递多个关联关系一次统计多个字段,还可以通过闭包函数指定对应统计的过滤条件: $post = Post::withCount(['tags', 'comments' => function...所以不管模型实例有多少个,关联结果只会查询一次,加上模型本身查询总共是两次查询,在列表查询时,大大减少了对数据库的连接查询次数,因而有更好的性能表现,推荐使用。...在渴求式加载中,也可以通过闭包传入额外的约束条件,只不过这个约束条件是对关联模型自身的过滤,不影响目标模型的查询: $post = Post::with(['comments' => function

19.6K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

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

    问题引出 在通过 Eloquent 模型实现增删改查这篇教程中,我们已经学习了如何在 Eloquent 模型类中进行各种查询,但是这些查询大多需要手动调用查询构建器提供的各种方法来实现。...「作用域」都是围绕模型类展开的,不管是全局作用域还是局部作用域,都是作用到某个模型类上。接下来,我们就来演示如何在 Eloquent 模型类上使用「作用域」进行查询。...以 User 模型类为例,我们在系统中可能只想针对已经验证过邮箱的用户进行操作,在没有介绍「作用域」之前,可能你会在应用中到处编写这样的代码: $users = User::whereNotNull('...通过匿名函数实现 如果你觉得编写一个「全局作用域」类很麻烦,过滤逻辑又很简单,还可以在模型类的 boot 方法中通过匿名函数实现全局作用域: protected static function boot...「局部作用域」的实现也比较简单,在需要应用它的模型类中定义一个过滤器方法即可。

    2.5K20

    在 Laravel 中使用 emoji 表情

    emoji 在生活中已经无处不见,微信昵称大把的都在用 emoji,那么在 Laravel 中如何对它进行正确的使用呢?...首先要了解一点基础知识: emoji 基本在各平台都有默认支持,但是都是基于 unicode 的,比如 “?”,它并不是图片,在不同的系统平台可能还不一样。...首先在 Laravel 中我们要支持 emoji 第一步,数据库字符集得为 utf8mb4,它是支持 emoji unicode 的字符集,比如我们要存储微信用户的昵称。...这里推荐使用我写的一个 laravel 拓展包:https://github.com/overtrue/laravel-emoji。...为我们提供了比较方便的 API 来在各种 emoji 展示方式间转换。 ? 更多使用请参考:https://github.com/overtrue/laravel-emoji。

    1K30

    在 Laravel 应用中构建 GraphQL API

    代码示例:产品列表和用户列表的 API 例子 昨天我们学习了 在 Visual Code 中搭建 Laravel 环境,现在我们来学习 Facebook 的 GraphQL 。...安装 Laravel 使用下面命令安装最新版本的 Laravel : # 在命令行中执行 composer global require "laravel/installer" laravel new...添加 GraphQL 的包 使用 composer 安装 graphql-laravel,这个包提供了非常多的功能用于整合 Laravel 和 GraphQL 。 3....创建模型 像下面这样创建模型和表 user_profiles, products, product_images,别忘了还要创建模型间的关系。 ? 4....Testing 我们可以使用 GraphiQL 来十分简单地编写查询语句,因为在编写的时候它可以自动补全,或者我们也可以使用 postman 来请求 API,下面是自动补全的示例: ?

    3.4K20

    在 Laravel 中使用 Trait 优化代码结构

    今天给大家介绍的是在 Laravel 中使用 Trait 优化代码结构,说起 Trait ,我一开始不知道是什么样的存在,有个模糊的印象是:复用。...\auth()->id();} // 封装一个上述公共方法,然后在模型中调用,或者在控制器中调用。 从上面的示例中发现这些操作都不是很好,不够优雅,哈哈。...现在我们来看看 laravel 中 Trait 是如何定义和使用的: // 定义 trait HasCreator{ public static function bootHasCreator()...模型中去了,要想使用就 use 一下,然后当自己声明的一样去调用就好了。...结束语 就简单的给大家介绍一下 Trait 在 Laravel 中如何使用的,写的不对的地方和补充欢迎大家留言噢,哈哈。

    1.5K20

    在 Laravel 项目中使用 Bootstrap 框架

    1、Laravel 如何引入 Bootstrap 如官方文档所言,Laravel 并不强制你使用 CSS 框架,但是开箱提供了对 Bootstrap 的支持,在 resources/js/bootstrap.js...(在 Laravel 5.7 之前的版本位于 resources/assets/js/bootstrap.js)中,我们可以看到对 bootstrap js库的引入: try { window....5.5 开始 Laravel 使用的 Bootstrap 版本就是 4....如果你使用的开发环境是 Homestead 的话,那么系统已经为你安装好了,去 Homestead 中执行即可;如果你使用的是 Laradock 的话,需要在 laradock/.env 中设置 WORKSPACE_INSTALL_NODE...Laravel Mix 是对 Webpack 进行封装后提供给 Laravel 项目使用的前端打包工具,Webpack 是目前最新的、广泛使用的前端资源打包工具(之前还有 Grunt、Gulp 等),能够以模块方式处理所有前端资源

    3.4K31

    Laravel 框架中对Layer的使用

    近期发现开源作者一直在进行维护,并且注意到了拥有让人喜欢的LayUI设计风格,感觉之前真的是有点浪费了 不管他人如何评价、质疑,自己作为后端开发人员更是layer的忠实拥护者,推荐学习一下 官网:...♫ 使用步骤 ①. 下载框架源码 个人下载的是 layui.2.2.45 版本,解压后放置于自己的项目 Public 目录下. ? ②. 引入 js , css 文件 ?...依个人习惯,我新建了 layui.blade.php 文件来存放相关的配置数据,如此一来,哪个页面需要,直接使用 @include()命令引入此文件即可 源代码参考如下: <link href="{{...相比前端的那些走在前沿的开发者们多在追求更新的框架潮流,而作为后端开发人员本没有更多的学习精力却要处理好多前端问题,这是一个不错的选择 当然,如果小组开发,建议多多交流,如果对方强烈不接受,可考虑其他解决方案,毕竟还不是主流框架,在团队合作以及他人代码维护上可能会有很大的阻碍...但是,在自己看来,极为欣赏这一框架的方便和优雅性,在此,为作者“闲心”点赞.

    2K30

    在PHP中strpos函数的正确使用方式

    首先简单介绍下 strpos 函数,strpos 函数是查找某个字符在字符串中的位置,这里需要明确这个函数的作用,这个函数得到的是位置。 如果存在,返回数字,否则返回的是 false。...而很多时候我们拿这个函数用来判断字符串中是否存在某个字符,一些同学使用的姿势是这样的 // 判断‘沈唁志博客’中是否存在‘博客’这个词 if (strpos('沈唁志博客', '博客')) {...沈唁志博客’中的第 0 个位置;而 0 在 if 中表示了 false,所以,如果用 strpos 来判断字符串中是否存在某个字符时 必须使用===false 必须使用===false 必须使用=...==false 重要的事情说三遍,正确的使用方式如下 // 判断‘沈唁志博客’中是否存在‘博客’这个词 if (strpos('沈唁志博客', '博客')===false) { // 如果不存在执行此处代码...原创文章采用CC BY-NC-SA 4.0协议进行许可,转载请注明:转载自:在PHP中strpos函数的正确使用方式

    5.2K30

    【Laravel系列4.4】模型Eloquent ORM的使用(二)

    模型Eloquent ORM的使用(二) 对于模型的探索我们还将继续。上篇文章中,只是简单地通过模型操作了一下数据库,并且学习了一下关联操作的知识。...比如说我们可以使用类似于 array_map() 的函数把集合中的对象全部转换成数组,还可以用一个类似于 array_column() 的函数只获取数据中的两个字段组成键值对形式的数据。...而另外一个 map() 函数就不用多说了,之前我们说过,Laravel 的 PDO 在默认查询构造器的情况下,走的是 PDO::FETCH_OBJ ,获得的集合结果中的每个数据都是一个 stdClass...而我们在日常的操作中,其实最习惯的是使用数组那种形式的操作,除开我们后面会讲的直接从配置入手来修改 PDO FETCH 属性之外,我们还可以用上面这个 map() 函数配合模型对象的 attributesToArray...但是,这里划重点了,Eloquent\Builder 中有些方法是没有的,比如说 insert()、insertGetId() ,在模型中,使用 save() 就可以代替这两个方法的操作。

    2.8K20

    怎么在 Laravel 中移除核心服务-视图

    create-project laravel/laravel=7.* laravel-demo 然后我们直接使用内置的服务运行 cd laravel-demo && php artisan serve...然后我们开始注释config/app.php中的视图提供者Illuminate\View\ViewServiceProvider::class, 再次访问首页 Laravel 可以看到已经出现错误..., 从Session中获取错误, 然后共享到视图里, 这里就会依赖视图服务, 我们注释掉这个中间件 然后再次访问首页 Laravel 如果Laravel版本低的话,Illuminate...($request, $exception); } 再次访问页面就可以看到自定义的错误了 错误 More 上面已经说了如果移除服务,但是项目API和admin混合,admin需要使用视图...这种时候我的建议是在config/app.php增加一个配置enable_admin, 然后判断当前环境是API移除掉不必要服务提供者,也不要启动后台的服务,具体可查看减少服务提供者的启动加速你服务的性能

    12710
    领券