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

3分钟短文 | Laravel获取关联表指定列的3个方法

今天我们说一说,在Laravel中,如何关联模型,以及制定返回列,以精简返回数据。 学习时间 假如有两个模型 User 和 Post,一个用户会发布多个post,也就是一对多的关联关系。...在Post模型中,必然有一个发布者,是一对一的映射: public function user(){ return $this->belongsTo('User'); } 现在假如有一个查询,获取所有的帖子...`id` in (, ) 显然,第二条SQL语句,返回了user表的所有列,数据量有可能很大。是否可以返回指定列呢?这样可以精简输出,减少MySQL的传输负荷。...}))->get(); 闭包内$query拼接SQL语句,并指定 select 选取的列,那么框架生成的SQL语句,就只会返回 id,username 列。...public function user() { return $this->belongsTo('User')->select(array('id', 'username')); } 特殊性 在Laravel5.5

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

    通过 Laravel 表单请求类实现字段验证和错误提示

    在上一篇教程中,我们已经演示了如何在控制器方法中对表单请求字段进行验证,并且提到如果请求字段很多很复杂,都写到控制器方法里面会导致控制器臃肿,从单一职责原则来说需要将表单请求验证拆分出去,然后通过类型提示的方式注入到控制器方法...今天,我们就来实现这个拆分,Laravel 提供了表单请求类的功能帮助我们快速完成这一架构调整。...答案是将其以类型提示的方式注入到请求路由对应的控制器方法即可,在本例中,就是 RequestController 的 form 方法: public function form(SubmitFormRequest...由于该表单请求类也是 Illuminate\Http\Request 的子类,所以后续获取请求字段值也可以通过 $request 来获取,将表单请求验证和请求实例参数合二为一,非常方便。...官方文档,里面很全,我就不一一列举了。

    3.9K30

    Laravel中Facade的加载过程与原理详解

    前言 本文主要给大家介绍了关于Laravel中Facade加载过程与原理的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。...PackageManifest::class)->aliases() ))->register(); } 默认的别名配置是从 app 配置文件下的 aliases 读取的,PackageManifest 是 laravel...$args); } getFacadeRoot 方法用于获取别名类的具体实列,我们知道,所有的 Facade 类都需要定义一个 getFacadeAccessor 方法。...该方法可能的返回值有: String 类型的字符串(如 config, db) String 类型的类字符串 (如 AppServiceSomeService) Object 具体的实列化对象 Closure...'config'; } getFacadeRoot 方法将根据 getFacadeAccessor() 的返回值,从容器从取出对应的实列对象。

    57330

    需要掌握的 Laravel Eloquent 搜索技术

    php $keyword = 'foo'; // 获取以 foo 开始,以任何字符结尾的文章 $result = Post::where('title', 'like', '{$keyword}%')-...>get(); // 获取以任何字符开始,但以 foo 结尾的文章 $result = Post::where('title', 'like', '%{$keyword}')->get(); // 获取包含...在 JSON 列中搜索 JSON 类型让数据存储拥有灵活性,这个功能很赞。Laravel 中也可以轻松执行对 JSON 数据的查询,这得益于 Laravel 良好的 JSON 支持。...不过在深入研究之前需要注意的一点是:谨记 JSON 列的存储是 区分大小写 的。 而如果我们需要查询的数据不存在 区分大小写 的问题,可以执行类似下面的查询语句: Laravel changelog 执行 sound like 操作,会进行一个发音相似性的算法,然后获取结果集。

    3.5K10

    需要掌握的 Laravel Eloquent 搜索技术

    php $keyword = 'foo'; // 获取以 foo 开始,以任何字符结尾的文章 $result = Post::where('title', 'like', '{$keyword}%'...)->get(); // 获取以任何字符开始,但以 foo 结尾的文章 $result = Post::where('title', 'like', '%{$keyword}')->get(); /...在 JSON 列中搜索 JSON 类型让数据存储拥有灵活性,这个功能很赞。Laravel 中也可以轻松执行对 JSON 数据的查询,这得益于 Laravel 良好的 JSON 支持。...不过在深入研究之前需要注意的一点是:谨记 JSON 列的存储是 区分大小写 的。 而如果我们需要查询的数据不存在 区分大小写 的问题,可以执行类似下面的查询语句: Laravel changelog 执行 sound like 操作,会进行一个发音相似性的算法,然后获取结果集。

    4.3K20

    掌握 Laravel 的测试方法

    继而,讲解如何在 Laravel 项目中创建「单元测试」和「功能测试」用例。...单元测试和功能测试 如果您已经接触过 PHPUnit 框架,那么您应该知道,它支持两种类型特性 -- 「单元测试」和「功能测试」。 「单元测试」的目的是用于测试函数或方法的正确性。...接下来我们将创建具体的测试用例,来讲解如何在 Laravel 中使用「单元测试」和「功能测试」。 搭建测试环境 创建测试模型 在开始创建测试用例前,我们需要先构建起用于测试的项目依赖。...之后,我们通过 Post 模型获取经过 getNameAttribute 方法处理过后的同一篇文章的标题赋值给 $model_post_title。...以上就是如何在 Laravel 中使用单元测试的使用方法。 功能测试 这一节我们将学习如何创建功能测试用例来对先前创建的控制器进行「功能测试」。

    5.7K10

    Laravel框架的核心架构,你懂多少?

    使用过larave框架的朋友都知道laravel框架里面除了提供一些基本的功能(如控制器、视图、模型)之外,还有中间件、门面、契约等,这些东西是如何在laravel框架运用起来的呢?...首先应该了解laravel框架的架构模式(设计核心,laravel 框架是使用服务组件化的开发模式开发的,laravel框架就是由不同的服务组件构成的) laravel 里面多个服务提供者构成了laravel...laravel里面的服务容器位于 vendor/laravel/frameworksrcilluminateContainerContainer.php....门面 门面再一次展示了Laravel在设计上的优秀,它让Laravel变得更加灵活易扩展,那么它的概念是: 1 为开发者提供服务容器中服务的静态代理 2 它对服务访问方式做了补充,之前使用服务必须获取服务的实例...对于我们的用户(最上面的用户)想使用laravel框架,必须通过控制器来使用(上面的Controller),使用laravel框架主要是使用laravel里面的服务提供者(上面的 new 服务),这样就是最传统的开发模式

    2.9K20

    Laravel 表单方法伪造与 CSRF 攻击防护

    相信你已经很熟悉,除此之外,HTTP 协议还定义了很多其他的请求方式,可以在 HTTP/1.1: Method Definitions 中查看 HTTP/1.1 协议支持的所有请求方式,不同的请求方式用于不同类型的请求...HEAD:与GET方法一样,都是向服务器发出指定资源的请求,但是服务器在响应 HEAD 请求时不会回传资源的内容部分(即响应实体),这样我们在不传输全部内容的情况下,就可以获取服务器的响应头信息。...POST:向指定资源提交数据,请求服务器进行处理,如:表单数据提交、文件上传等,请求数据包含在请求体中。POST 方法是非幂等的方法,因为这个请求可能会创建新的资源或修改现有资源。...答案是通过表单方法伪造,下面我们就来介绍如何在 Laravel 中进行表单方法伪造。...排除指定 URL 不做 CSRF 保护 对于应用中某些第三方回调路由,如第三方登录或支付回调,无法做 Token 校验,需要将这些授信路由排除在 CSRF 校验之外,这个功能可以参考官方文档实现,很简单

    8.7K40

    Laravel框架的核心架构,你懂多少?

    使用过larave框架的朋友都知道laravel框架里面除了提供一些基本的功能(如控制器、视图、模型)之外,还有中间件、门面、契约等,这些东西是如何在laravel框架运用起来的呢?...首先应该了解laravel框架的架构模式(设计核心,laravel 框架是使用服务组件化的开发模式开发的,laravel框架就是由不同的服务组件构成的) laravel 里面多个服务提供者构成了laravel...laravel里面的服务容器位于 vendor/laravel/frameworksrcilluminateContainerContainer.php....门面 门面再一次展示了Laravel在设计上的优秀,它让Laravel变得更加灵活易扩展,那么它的概念是: 1 为开发者提供服务容器中服务的静态代理 2 它对服务访问方式做了补充,之前使用服务必须获取服务的实例...对于我们的用户(最上面的用户)想使用laravel框架,必须通过控制器来使用(上面的Controller),使用laravel框架主要是使用laravel里面的服务提供者(上面的 new 服务),这样就是最传统的开发模式

    3K10

    Laravel 使用Excel导出的文件中,指定列数据格式为日期,方便后期的数据筛选操作

    背景 最近,后台运维要求导出的 Excel文件,对于时间的筛选,能满足年份、月份的选择 通过了解,发现: 先前导出的文件,默认列数据都是字符串(文本)格式 同时,因为用的是 Laravel-excel...@param array $cellData 数据 * @param string $sheetName 工作表名 * @param array $columnFormat 列格式...cellData); }); })->store('xlsx'); // 文件默认保存到storage/exports目录下 } /** * @notes:获取.../** * @notes:获取导出的数据 * @return array 注意返回的数据为 Collection 集合形式 * @author: zhanghj...导出的时候写入的日期格式数据怎么在excel中正确显示成可以筛选的日期格式数据 Laravel Excel 3.1 导出表格详解(自定义sheet,合并单元格,设置样式,格式化列数据)

    12510

    Vuebnb:一个用vue.js和Laravel构建的全栈应用

    在这篇文章中,我会把它如何工作做一个高层次的概述,好让你了解如何从零开始参与建设一个Vue/Laravel构建的全栈应用。...我还用Laravel安全认证的API调用,这是让用户能够保存他们喜欢的房间列表。 特征 该项目的功能主要包括UI组件以及应用程序的总体架构设计。...通过Laravel的验证接口来验证相关API调用。 在后端和前端之间共享数据 全栈应用程序的关键考虑之一是如何在后端和前端之间进行数据通信,所以我花了相当多的时间来处理这本书中的问题。...例如,有一列数据是从Laravel到内页的,Vue.js通过使用刀片视图来实现,可以很容易地使用模板变量向页面头部注入数据。这个数据可以在Vue应用程序中就初始化。...关于这本书 从Vuebnb的特点你会有一些涉及全栈Vue网站开发的话题:Vue.js,Vuex和Laravel。

    6K10
    领券