”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 对于 PHP 中的大型结果集,PDO::fetchAll() 总是更快吗?

对于 PHP 中的大型结果集,PDO::fetchAll() 总是更快吗?

发布于2024-11-20
浏览:694

Is PDO::fetchAll() Always Faster for Large Result Sets in PHP?

PDO::fetchAll 与 PDO::fetch 在循环中获取大型结果集

在 PHP 的 PDO 扩展中,有两个主要的从数据库查询中获取数据的方法:PDO::fetchAll() 和 PDO::fetch()。在处理大型结果集时会出现一个常见的性能问题。在速度和效率方面使用一种方法相对于另一种方法有显着的优势吗?

PDO::fetchAll() 从查询结果中检索所有行作为行数组,而 PDO::fetch() 一次获取一行。主要区别在于 PDO::fetch() 在内部循环结果集并将每一行存储在数组中,而 PDO::fetchAll() 在一次操作中将所有行提取到内存中。

直观地说,一个可能会认为 PDO::fetchAll() 由于其一次性操作而更快,从而消除了对多个循环的需要。然而,这个假设在实践中不一定成立,它取决于几个因素:

性能比较:

使用具有 200,000 条随机记录的表进行基准测试表明: PDO::fetchAll() 在循环中比 PDO::fetch() 稍快:

  • PDO::fetchAll(): 0.35965991020203 秒
  • PDO::fetch() :0.39197015762329秒

内存使用:

但是,考虑内存影响很重要。 PDO::fetchAll() 将整个结果集存储在内存中,这对于大型数据库来说非常重要。在同一基准测试中,PDO::fetchAll() 消耗了大约 100 MB 内存,而 PDO::fetch() 仅消耗了 440 字节。

结论:

基于这些观察,对于大型结果集,在循环中选择 PDO::fetchAll() 和 PDO::fetch() 取决于应用程序的具体要求:

  • 为了获得最大性能和尽量减少内存使用,建议使用 PDO::fetch()。
  • 对于速度至关重要且不关心内存可用性的场景,PDO::fetchAll() 可能会提供轻微的性能优势。

其他注意事项:

  • 将数据提取到自定义 PHP 对象中时,PDO::fetchAll() 和 PDO::fetch() 之间的性能差异可能是由于对象实例化的开销,不太明显。
  • 始终建议在现实条件下分析应用程序,以确定特定用例的最佳解决方案。
最新教程 更多>
  • 将图片浮动到底部右侧并环绕文字的技巧
    将图片浮动到底部右侧并环绕文字的技巧
    在Web设计中围绕在Web设计中,有时可以将图像浮动到页面右下角,从而使文本围绕它缠绕。这可以在有效地展示图像的同时创建一个吸引人的视觉效果。 css位置在右下角,使用css float and clear properties: img { 浮点:对; ...
    编程 发布于2025-04-21
  • 在Go语言中,`defer`语句后使用`()`的原因及作用
    在Go语言中,`defer`语句后使用`()`的原因及作用
    在go 考虑示例:尝试递延函数f本身,这是没有意义的。相反,正确的语法为: defer f(),此构建一个闭合,在激活defer语句时捕获当前上下文并执行函数f。外括号立即执行闭合,以确保在执行延期语句之后进行函数调用。defer func(n int) { fmt.Println(n) }(i)...
    编程 发布于2025-04-21
  • CSS强类型语言解析
    CSS强类型语言解析
    您可以通过其强度或弱输入的方式对编程语言进行分类的方式之一。在这里,“键入”意味着是否在编译时已知变量。一个例子是一个场景,将整数(1)添加到包含整数(“ 1”)的字符串: result = 1 "1";包含整数的字符串可能是由带有许多运动部件的复杂逻辑套件无意间生成的。它也可以是故意从单个真理...
    编程 发布于2025-04-21
  • Android如何向PHP服务器发送POST数据?
    Android如何向PHP服务器发送POST数据?
    在android apache httpclient(已弃用) httpclient httpclient = new defaulthttpclient(); httppost httppost = new httppost(“ http://www.yoursite.com/script.p...
    编程 发布于2025-04-21
  • 为什么HTML无法打印页码及解决方案
    为什么HTML无法打印页码及解决方案
    无法在html页面上打印页码? @page规则在@Media内部和外部都无济于事。 HTML:Customization:@page { margin: 10%; @top-center { font-family: sans-serif; font-weight: bo...
    编程 发布于2025-04-21
  • 查找当前执行JavaScript的脚本元素方法
    查找当前执行JavaScript的脚本元素方法
    如何引用当前执行脚本的脚本元素在某些方案中理解问题在某些方案中,开发人员可能需要将其他脚本动态加载其他脚本。但是,如果Head Element尚未完全渲染,则使用document.getElementsbytagname('head')[0] .appendChild(v)的常规方...
    编程 发布于2025-04-21
  • 如何从PHP中的数组中提取随机元素?
    如何从PHP中的数组中提取随机元素?
    从阵列中的随机选择,可以轻松从数组中获取随机项目。考虑以下数组:; 从此数组中检索一个随机项目,利用array_rand( array_rand()函数从数组返回一个随机键。通过将$项目数组索引使用此键,我们可以从数组中访问一个随机元素。这种方法为选择随机项目提供了一种直接且可靠的方法。
    编程 发布于2025-04-21
  • 手动触发桌面应用中的绘图事件方法
    手动触发桌面应用中的绘图事件方法
    [2 [2 油漆事件对于更新桌面应用程序中的图形用户界面(GUI)至关重要。 当动态更改面板上的文本之类的元素时,您需要手动触发重新粉刷以反映这些更改。本文详细介绍了如何完成此操作。 用于手动重新启动表格或控制类中的几种方法允许您强制重新涂抹: :此方法计划对控件进行重新涂漆。实际的重新绘制稍后发...
    编程 发布于2025-04-21
  • 如何检查对象是否具有Python中的特定属性?
    如何检查对象是否具有Python中的特定属性?
    方法来确定对象属性存在寻求一种方法来验证对象中特定属性的存在。考虑以下示例,其中尝试访问不确定属性会引起错误: >>> a = someClass() >>> A.property Trackback(最近的最新电话): 文件“ ”,第1行, attributeError:SomeClass实...
    编程 发布于2025-04-21
  • 使用jQuery如何有效修改":after"伪元素的CSS属性?
    使用jQuery如何有效修改":after"伪元素的CSS属性?
    在jquery中了解伪元素的限制:访问“ selector 尝试修改“:”选择器的CSS属性时,您可能会遇到困难。 This is because pseudo-elements are not part of the DOM (Document Object Model) and are th...
    编程 发布于2025-04-21
  • Java数组中元素位置查找技巧
    Java数组中元素位置查找技巧
    在Java数组中检索元素的位置 利用Java的反射API将数组转换为列表中,允许您使用indexof方法。 (primitives)(链接到Mishax的解决方案) 用于排序阵列的数组此方法此方法返回元素的索引,如果发现了元素的索引,或一个负值,指示应放置元素的插入点。
    编程 发布于2025-04-21
  • 如何将来自三个MySQL表的数据组合到新表中?
    如何将来自三个MySQL表的数据组合到新表中?
    mysql:从三个表和列的新表创建新表 答案:为了实现这一目标,您可以利用一个3-way Join。 选择p。*,d.content作为年龄 来自人为p的人 加入d.person_id = p.id上的d的详细信息 加入T.Id = d.detail_id的分类法 其中t.taxonomy =...
    编程 发布于2025-04-21
  • Python元类工作原理及类创建与定制
    Python元类工作原理及类创建与定制
    python中的metaclasses是什么? Metaclasses负责在Python中创建类对象。就像类创建实例一样,元类也创建类。他们提供了对类创建过程的控制层,允许自定义类行为和属性。在Python中理解类作为对象的概念,类是描述用于创建新实例或对象的蓝图的对象。这意味着类本身是使用类关...
    编程 发布于2025-04-21
  • 如何在php中使用卷发发送原始帖子请求?
    如何在php中使用卷发发送原始帖子请求?
    如何使用php 创建请求来发送原始帖子请求,开始使用curl_init()开始初始化curl session。然后,配置以下选项: curlopt_url:请求 [要发送的原始数据指定内容类型,为原始的帖子请求指定身体的内容类型很重要。在这种情况下,它是文本/平原。要执行此操作,请使用包含以下标头...
    编程 发布于2025-04-21
  • Go语言结构体深度解析
    Go语言结构体深度解析
    In Go, struct is an aggregate type used for defining and encapsulating data. It allows combining fields of different types. Structs can be seen as cus...
    编程 发布于2025-04-21

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3