*PostgreSQL 性能问题:`(func()).` 语法和冗余函数调用**
本文研究了 PostgreSQL 中与返回复合类型或集合的函数一起使用时与 (func()).*
语法相关的性能问题。 下面的查询中显示的原始观察结果突出显示了意外行为:
SELECT (func(3)).*; -- Leads to multiple function calls
问题:过度的功能评估
核心问题是 (func()).*
触发对函数输出中的 每个 列的单独函数调用。例如,返回四列的函数可能会导致八次函数调用,而不是预期的两次。 这与替代语法形成鲜明对比,例如:
SELECT N, func(N); -- More efficient approach
解决方案:高效查询重写
为了避免过多的调用,子查询提供了一种解决方法。 虽然通常有效,但这并不是一个完美的解决方案,并且可能会引入其他性能考虑因素。
对于 PostgreSQL 9.3 及更高版本,LATERAL
关键字提供了更好的解决方案:
SELECT mf.* FROM some_table LEFT JOIN LATERAL my_func(some_table.x) AS mf ON true;
根本原因:PostgreSQL 解析器行为
根本原因在于 PostgreSQL 的解析器如何处理 *
构造中的 (func()).*
通配符。 解析过程中通配符扩展到各个列是冗余函数调用的根源。
性能基准和演示
自定义函数示例演示了有问题的语法与建议的解决方法之间的性能差异。 测试表明子查询方法(或 CTE)提供了显着的性能改进。
结论:优化 PostgreSQL 中的查询
虽然 (func()).*
的多函数调用问题仍然是已知行为,但解决方法,特别是使用 LATERAL
(PostgreSQL 9.3),为开发人员提供了优化查询性能并减少不必要的函数评估的有效策略。
以上是为什么 PostgreSQL 中的 `(func()).*` 会导致多次函数求值?的详细内容。更多信息请关注PHP中文网其他相关文章!

本文探讨了Docker中的优化MySQL内存使用量。 它讨论了监视技术(Docker统计,性能架构,外部工具)和配置策略。 其中包括Docker内存限制,交换和cgroups

本文介绍了MySQL的“无法打开共享库”错误。 该问题源于MySQL无法找到必要的共享库(.SO/.DLL文件)。解决方案涉及通过系统软件包M验证库安装

本文讨论了使用MySQL的Alter Table语句修改表,包括添加/删除列,重命名表/列以及更改列数据类型。

本文比较使用/不使用PhpMyAdmin的Podman容器直接在Linux上安装MySQL。 它详细介绍了每种方法的安装步骤,强调了Podman在孤立,可移植性和可重复性方面的优势,还

本文提供了SQLite的全面概述,SQLite是一个独立的,无服务器的关系数据库。 它详细介绍了SQLite的优势(简单,可移植性,易用性)和缺点(并发限制,可伸缩性挑战)。 c

本指南展示了使用自制在MacOS上安装和管理多个MySQL版本。 它强调使用自制装置隔离安装,以防止冲突。 本文详细详细介绍了安装,起始/停止服务和最佳PRA

文章讨论了为MySQL配置SSL/TLS加密,包括证书生成和验证。主要问题是使用自签名证书的安全含义。[角色计数:159]

文章讨论了流行的MySQL GUI工具,例如MySQL Workbench和PhpMyAdmin,比较了它们对初学者和高级用户的功能和适合性。[159个字符]


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

螳螂BT
Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具

VSCode Windows 64位 下载
微软推出的免费、功能强大的一款IDE编辑器

记事本++7.3.1
好用且免费的代码编辑器

Atom编辑器mac版下载
最流行的的开源编辑器