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

为什么在使用完Laravel中的WHERE之后还要循环获取数据呢?

在使用Laravel中的WHERE之后还需要循环获取数据的原因是,WHERE语句只是用来筛选数据库中符合条件的数据,但并不会直接返回这些数据。WHERE语句只是在数据库中执行查询操作,返回的是一个查询结果集,而不是具体的数据。

为了获取具体的数据,我们需要通过循环遍历查询结果集,逐条获取数据。这是因为查询结果集通常是一个包含多条记录的集合,我们需要逐条处理每条记录,进行进一步的操作或展示。

在循环获取数据时,可以使用Laravel提供的查询构建器或ORM(对象关系映射)模型来简化操作。通过这些工具,我们可以方便地对查询结果进行遍历,并对每条记录进行进一步的处理。

需要注意的是,循环获取数据可能会导致性能问题,特别是当查询结果集非常大时。为了提高性能,可以考虑使用分页技术,每次只获取部分数据,而不是一次性获取全部数据。

总结起来,使用Laravel中的WHERE语句筛选数据后,需要循环获取数据是因为WHERE语句只返回查询结果集,而不是具体的数据。通过循环遍历查询结果集,我们可以逐条获取数据并进行进一步的处理。

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

相关·内容

为什么 Laravel 这么优秀?

我准备从一个后端最常用的 CURD 例子说起,一步一步阐述这过程中 Laravel 都是怎么完成的;以及~大家~(我)为什么喜欢用 Laravel。...container 中设置不同的值;如 CacheServiceProvider 会向容器中注册 Cache 对象,后续在使用 Cache::get 时就使用的是这里注册的 Cache 对象,在注册阶段不应该向容器中获取值...Laravel 会自动帮我们从容器中获取它,如果容器不存在,则会尝试初始化它。...而 Laravel Pipeline 的实现也很有趣;我们知道在常见的 Pipeline 设计中,大多会通过 for 循环来实现,而 Laravel 则采用的是最简单却又最复杂的实现 array_reduce...不过我觉得 Laravel 的不足不在性能,毕竟 PHP 作为脚本语言,就算我们把它优化到极致,也不可能达到类似 Go 那么高的吞吐率,如果真的是为了性能,那为什么不选择其他更适合的语言呢?

26710

Sight——杀手级提升Laravel开发速度的组件现在开源了!

今天,给大家推存一个Laravel的专用组件:Sight Laravel开发速度可以算是最快的了。但是,现在如果加上Sight,那么,你的开发速度会更加快。 Sight做了什么呢?...Sight是在Server Side实现了一个Presenter层。从而让你把从服务器中查出的数据轻松转换为可展示的数据。...自从有了Sight,Laravel成了唯一支持Server Side的MVP模式的框架。 为什么要用Sight呢? 一、是加快开发速度。 二、国内的Phper都了解,大厂是禁止SQL联表三个表以上的。...遇到初学者,会在FOR循环中查询数据库。如果你禁止了,则还有可能是,他们把相关ID PLUCK出来。查出结果,然后,再FOR循环中嵌套FOR循环去查相关的关联数据。...我们看出:created_at所用的是MappingTypeEnum::METHOD_NAME,这个方法在哪里呢,是在PresenterTrait中。所以,你也可以定义自己的Trait。

79300
  • 在 Laravel 应用中构建 GraphQL API

    代码示例:产品列表和用户列表的 API 例子 昨天我们学习了 在 Visual Code 中搭建 Laravel 环境,现在我们来学习 Facebook 的 GraphQL 。...GraphQL 是一种 API 查询语言,还是一种根据你为数据定义的类型系统执行查询的服务器端运行时。GraphQL 不依赖于任何指定的数据库或存储引擎,而是由你的代码和数据来作支持的。...graphql.org GraphQL 可以提升 API 调用的灵活性,我们可以像写数据库查询语句一样来请求 API 来获取所需要的数据,这对构建复杂的 API 查询来说非常有用。...安装 Laravel 使用下面命令安装最新版本的 Laravel : # 在命令行中执行 composer global require "laravel/installer" laravel new...创建查询和定义 GraphQL 的类型 GraphQL 中的查询与 Restful API 中的末端路径查询是一样的,查询只是用于获取数据,以及创建、更新、删除操作。

    3.4K20

    【Laravel系列4.2】查询构造器

    之后的操作就全都是针对这个指定的表名了。接下来,我们就可以通过链式调用的方式进行数据库的操作。先来看简单的增删改。...在 Laravel 中,默认情况下这个值设置的就是 PDO::FETCH_OBJ 。关于如何修改成 PDO::FETCH_ASSOC ,我们会在后面的文章中学习。...最后,我们还有一个获取单个数据的方法 find() ,它和 delete() 很类似,只需要一个主键 ID 就可以了。...在 查询构造器 中,还有其它很多的链式函数可以实现非常复杂的数据库操作,大家可以自己去研究一下。...我们又发现了一个设计模式在 Laravel 框架中的应用,意外不意外,惊喜不惊喜! 连表查询 普通的连表查询的使用还是非常简单的,我也就不多说了,下面的代码中也有演示。

    16.8K10

    【Laravel系列4.3】模型Eloquent ORM的使用(一)

    赶紧查看错误信息,竟然是这个 laravel.m_tests 表不存在。小伙伴们不要惊讶,在这里出错是正常的,为什么呢?...这样看貌似没问题呀,可是为什么报错的是 m_tests 表不存在呢?这就牵涉到上面 Active Record 的概念了,在 AR 中,一个类对应的是一张表,而一张表是由多行数据组成的。...在英文命名中,复数一般都会加 s 的,所以,如果是走的自动映射表名的话,会在大驼峰转换之后再加一个 s 到表名后面。 好吧,原来如此,但是这样我们就用不了这个表了?...在这里比较奇怪的是,我们在实例化和赋值的过程中没有给对象的主键 id 赋值,但是在 save() 之后,id 就有值了,而且是我们新插入的数据 id ,是不是很高大上。...这样做的原因也正是为了保持数据的一致性和完整性。 当然,在 Laravel 中,可以不在数据库层面进行严格的设置,就可以在框架代码中实现主外键的关联。

    8.9K20

    需要掌握的 Laravel Eloquent 搜索技术

    本文将带领大家学习 MySQL 和 Eloquent 在搜索模块中设计的相关技术。 基本的 Eloquent Where 查询 作为首个要讲解的搜索功能,我们先不涉及新知识点。...在 Laravel 中可以使用 where 方法实现对给定字段和给定值进行比较查询,就是这样简单。 在文档中找到。 在 JSON 列中搜索 JSON 类型让数据存储拥有灵活性,这个功能很赞。...Laravel 中也可以轻松执行对 JSON 数据的查询,这得益于 Laravel 良好的 JSON 支持。 不过在深入研究之前需要注意的一点是:谨记 JSON 列的存储是 区分大小写 的。...但是这并不是我们需要关注的,我们仅需将待查询的字符串传给 where 语句即可。返回的结果集即会包含完全匹配的数据,也会包含发音近似的数据。 总结 Laravel 为我们提供了简单实用的查询功能。

    3.5K10

    【Laravel系列4.5】主从库配置和语法生成

    但是你要知道的是,Laravel 以及现代化的所有框架都是可以方便地配置主从分离的。另外,我们还要再回去 查询构造器 中,看一下我们的原生 SQL 语句的拼装语法到底是如何生成的。...主从数据库连接 其实配置非常简单,我们先来简单的看一下。之后,我们再深入源码,看看它是怎么做到写入走主库,读取走从库的。...这也是因为我们在某些业务中,需要在操作完数据后马上查询,主从之间的延迟可能会导致查询的从库数据不正确(这在现实业务中很常见)。...这一个循环是在干嘛?其实,从代码中我们可以看,它在遍历一个本地属性 selectComponents ,并根据这个属性里面的内容去调用自身的这些方法。...后面我们还要再学习两篇简单的和数据库相关的内容,分别是事务与PDO属性设置,以及 Redis 的简单使用。

    4.3K20

    Laravel源码笔记(二)路由

    整个路由服务的框架大致如下: image.png 在两个服务周期中都扮演者重要角色的Router路由器,是在laravel初始化的过程中由RoutingServiceProvider注册到...实际上,所有 laravel 路由都定义在位于 routes 目录下的路由文件中,这些文件内的路由被laravel视为一个大的路由组,在RouteService启动的过程中通过Route门面加载出来(所以路由配置文件不需要声明对...,将domain、prefix这些熟悉的注册处理转交给RouteRegistrar,并在自身处理method之后返回生成的路由实例Route,将where、name等约束的处理交给Route进行。...其次,这里用到了上一步获取的第一个可选参数位置,因为在子命名组语法中规定: 若当前路由参数不是可选参数的时候,正则表达式就是固定模式,例如:/(?.../tai l$#s 3.3 参数绑定         得到一个路由的正则表达式regex之后,laravel就可以后续处理请求的时候使用它了:一是用来匹配url,二是用来获取url参数。

    7.5K40

    需要掌握的 Laravel Eloquent 搜索技术

    本文将带领大家学习 MySQL 和 Eloquent 在搜索模块中设计的相关技术。 基本的 Eloquent Where 查询 作为首个要讲解的搜索功能,我们先不涉及新知识点。...在 Laravel 中可以使用 where 方法实现对给定字段和给定值进行比较查询,就是这样简单。 在文档中找到。 在 JSON 列中搜索 JSON 类型让数据存储拥有灵活性,这个功能很赞。...Laravel 中也可以轻松执行对 JSON 数据的查询,这得益于 Laravel 良好的 JSON 支持。 不过在深入研究之前需要注意的一点是:谨记 JSON 列的存储是 区分大小写 的。...但是这并不是我们需要关注的,我们仅需将待查询的字符串传给 where 语句即可。返回的结果集即会包含完全匹配的数据,也会包含发音近似的数据。 总结 Laravel 为我们提供了简单实用的查询功能。

    4.3K20

    Laravel 模型操作中一次奇妙踩坑经历

    返回的数据是没有整合进 commonTask 的,这是为什么呢,明明 $userTask->tasks->merge($tasks) 也赋值了呀,问题出在哪里呢,我们测试一下: ......具体的数据打印结果我就不贴出来了哈,占地方,哈哈,我直接说结果。 从打印的结果中可以看到 $userTask->tasks 中是有合并之后的数据的,但是 $userTask 还是原先的数据。...既然 attributes 被修改了,那究竟为啥在输出的时候只有他本身的属性有变更但是关联属性没有呢?...$userTask 中 attributes 是有变更,但是 relations 中的数据是没有发生任何变化的,这就可以解释为什么赋值 tasks 没有任何效果了,原有的数据覆盖掉了变更的数据。...大家知道在控制器中直接 return 的时候,是会直接转化为 Json 数据格式的,模型中也相对应的有这么一个方法: ? ? 一步步走下来发现,最终还是调用了 toArray 。

    1.6K30

    【Laravel系列3.2】路由:指哪儿打哪儿

    从这里也能够看出,Laravel 的路由对于数据安全的好处。大部分情况下,我们使用的接口都会以 POST 为主,特别是数据提交的接口。...如果是传统框架没有加任何判断的情况下,也是可以直接请求到控制器的,只是说我们从 _POST 中无法获取数据而已。...这种情况下,如果处理得当一般也不会有什么问题,但有可能也会造成意外的数据泄露,比如说万一我们使用 _REQUEST 来接收数据。在 Laravel 中路由处理的时候,就会将这个问题给避免了。.../route/user/1 // Erwin Ortiz 上述代码中,我们需要参数名称和模型对象的参数名称相同,然后在 URL 中传递对应数据的 ID ,这样就可以直接查询到模型对象对应的数据信息。...接下来,就回到路由文件中 temp 这个路由的回调函数中。之后就是响应的输出了。 整个路由功能的调用路径就是这样,其实相对来说没有请求响应的路径长,毕竟它只是请求响应路径中的一部分而已。

    11.8K10

    【Laravel系列4.1】连接数据库与原生查询

    连接数据库与原生查询 在 PHP 的学习中,数据库,也就是 MySQL 就像它的亲兄弟一样,永远没法分家。同理,在框架中,数据库相关的功能也是所有框架必备的内容。...我们还能看到许多其它数据库的配置,不过,今天我们的重点还是在 mysql 这个配置中。...从 options 这个参数里面,我们可以看出,Laravel 默认使用的是 PDO 连接的数据库,我也没有研究在 Laravel 中如何使用 mysqli 进行连接,因为 PDO 确实已经是事实的连库标准了...这就很诡异了吧,为什么要这样呢?直接提供一个方法让我们进行操作就好了嘛。其实,这也正是 Laravel 优雅的由来。为了更好地区分度和代码的清晰。...首先,我们新建一个数据库,就叫 laravel8 好了,并且同样的建立一个 raw_test 表,然后就是在 .env 中配置这个数据库的连接信息。

    3.2K50

    【Laravel系列3.1】​一个请求的前世今生

    同时,在 Laravel 中,我们在中间件中也可以获取到这些参数,整个 request 是贯穿所有的框架对象的,也就是它在整个请求生命周期中都是存在的,并且一直是向下传递的。...为什么是 all() 方法呢?因为我们没指定是 get 还是 post 来的数据。 在 request 中,有对应的 get() 和 post() 方法,同时也存在一个 all() 方法。...大家在调试过程中,可以看到请求参数都在 InputBag 的 parameters 属性中。 那么,这个属性是在什么时候获得参数信息的呢?...代码处理完业务逻辑之后,需要打印数据进行展示,这个过程其实就是一次响应的过程。有请求,有响应,构成了一个完整的数据 请求/响应 模型。...当然,我们只是研究了一下直接返回字符串的 Response 过程,其它的如 view() 返回模板的过程会更复杂一些,因为还要牵涉到视图模板数据的解析编译以及缓存。

    7.5K20

    【Laravel系列8】走出 Laravel 的世界

    走出 Laravel 的世界 还记得这个系列的第一篇文章是什么吗?当时我们写的是《进入Laravel的世界》。照理说,学习完了,日常应用更得心应手了,我们为啥又要走出呢?...又是一个新的开始 对于我们的人生来说,就是在不断地进行着开始与结束的循环。在开始的时候,我们走进 Laravel 的世界。...我们就直接去学习 Swoole 中的应用功能,以及一个和 Laravel 非常像的 Swoole 框架:Hyperf 。...不过这也印证了一个道理,天下大同,不仅是语言,这些框架也在越来越接近,越来越类似。 如果你还要继续深入地学习一些编程思想,现在应该去看一看 Java 相关的框架了。...你可以在这些框架中寻找到 Laravel 中许多实现的影子。如果你本身就是在用 Laravel ,去拓展一下眼界也没什么不好。不说谁抄谁,思想都是开源的,这点你必须承认。

    1.2K30

    【Laravel系列2.2】Laravel 目录结构与配置

    其实从这些配置文件的名字就可以看出它们的作用。在接下来的文章中我们马上就要接触到的就是 database.php 这个文件,因为在入门相关的内容中,我们还是要简单地连下数据库体验一下的。...在 database.php 中,不仅可以定义要连接的 mysql 数据库信息,也可以定义要连接的 NoSQL 类型的数据库(默认已经给了 redis 的连接配置)。...$bootstrapper, [$this]); } 其中核心是 this->make(this); 这一段,它在循环中会加载所有 bootstrappers 数组中的内容,这个数组里面的内容是在 laravel...之后的读取,也直接是读取这个 _SERVER 中的数据。...Laravel 就是将 .env 文件中的数据缓存到了全局变量 $_SERVER ,然后我们在将来使用的时候就直接从全局变量中获取就可以了,这样就可以避免下一次还要从文件读取,从而提高系统效率。

    4.4K30

    3分钟短文 | Laravel复杂SQL超多WHERE子句,本地作用域你没用过

    引言 使用框架就是为了方便把注意力集中在逻辑上,而不用关心与数据库操作的方方面面。...Laravel提供的 eloquent orm 使用面向对象的方式封装了PDO数据库操作,使用起来非常方便,对于复杂的SQL操作也游刃有余。...今天说一说,复杂的超多的WHERE子句,怎么写起来较为优雅。 学习时间 比如对于业务逻辑中,User模型在筛选查询的时候有非常多的限制条件,类似下面这样的: ?...Laravel 的软删除功能就是利用此特性从数据库中获取 “未删除”的模型。 你可以编写你自己的全局作用域,很简单、方便的为每个模型查询都加上约束条件。看官方给出的示例: ?...就是在对应的 Eloquent 模型方法前添加 scope 前缀,在模型中构造如下的作用域方法: ?

    2.8K10

    从0开始做一个审批模块

    说到数据表的命名,我觉得也是一门学问,不单单是数据表的命名,但凡涉及到命名的就是一门高深的学问,往往有的时候命名的时间,比我写一个方法函数的时间还要长,无奈一直找不到精髓所在。...我第一个想到的就是 applications ,有一个书面申请的含义在,也是个名词,可惜这个单词在我们数据库中已经被占用,作为『应用』表了。...:『Laravel 中多态关系的表单验证[3]』 。...上面的内容其实跟 申请事务处理 的设计是一样样的,至于为什么把 通知 单独出来讲主要是为了以下程序的设计。 审批通知列表 在需求方发送申请之后,其对应的管理员的审批列表该如何呈现呢?...如果说直接取 applies 表中的数据进行展示的话,那得一条条数据进行遍历,判断当前用户是否可以看到本条申请.....

    1.7K10

    PHPer面试指南-laravel 篇

    分发请求:一旦应用完成引导和所有服务提供者都注册完成,Request 将会移交给路由进行分发。路由将分发请求给一个路由或控制器,同时运行路由指定的中间件 服务提供者是什么?...Laravel 中的服务容器是用于管理类的依赖和执行依赖注入的工具。 Facades 是什么?...此外,由于对 PHP 动态方法的独特用法,也使测试起来非常容易。 Contract 是什么? Contract(契约)是 laravel 定义框架提供的核心服务的接口。...谈谈 Laravel 和 YII 框架的区别 在 YII 框架中的路由是通过书写 Controller、Action 间接定义路由,而 Laravel 中是在 route 路由文件中直接定义路由入口...Laravel 提供 ORM 对象关系映射,使读写数据库的操作更加简单 Laravel 提供更多的 Artisan 命令和脚手架开发 Laravel 的 Composer 扩展包比

    1.1K20

    3分钟短文:Laravel应用跟用户打交道,就从拿到他们的数据开始!

    而laravel是偏重后端的,所以为了给后端的开发同学缓冲的时间,我们跳过视图,先来说说用户数据的获取和处理,这几乎是任何应用必备之功能。 用户数据同时又是危险的!本文不会教你规避危险!...代码时间 我们在讲路由规划的时候,说了如何使用url的位置参数绑定的方式进行导向,其实那也是一种获取用户输入数据的方式, 只不过,传入的位置参数一般都人畜无害,公开访问,任你来来往往。...laravel把用户的输入存储在 Input 对象内,而从逻辑上看,用户输入应该归属于请求项的,所以 Request 也继承了 Input 的方法和数据。...有同学会疑问,为什么有了 has还要 exists呢?因为他们的作用不同。...内获取数组可以使用点式方式读取,这是因为laravel解析的时候使用了助手类 Arr 的通用方法。

    1.5K00

    3分钟短文:Laravel应用跟用户打交道,就从拿到他们的数据开始!

    而laravel是偏重后端的,所以为了给后端的开发同学缓冲的时间,我们跳过视图,先来说说用户数据的获取和处理,这几乎是任何应用必备之功能。 用户数据同时又是危险的!本文不会教你规避危险!...代码时间 我们在讲路由规划的时候,说了如何使用url的位置参数绑定的方式进行导向,其实那也是一种获取用户输入数据的方式, 只不过,传入的位置参数一般都人畜无害,公开访问,任你来来往往。...laravel把用户的输入存储在 Input 对象内,而从逻辑上看,用户输入应该归属于请求项的,所以 Request 也继承了 Input 的方法和数据。...有同学会疑问,为什么有了 has还要 exists呢?因为他们的作用不同。...内获取数组可以使用点式方式读取,这是因为laravel解析的时候使用了助手类 Arr 的通用方法。

    1.4K10
    领券