请问下 PHP 里面遇到联合查询是用 foreach 还是用联表查询

2016-10-14 16:43:10 +08:00
 zhangjieren

如题 当遇到多个表关联 需要查询出来的 时候 考虑到效率和资源的问题 是应该联表还是 foreach 第一张底表 然后去各个表里单独查询? 还是有说有更好的解决办法? 还有个问题 就是一般排序的话是用 mysql 的 ORDERBY 还是拿出来用 PHP 排序? MYSQL 的 ORDERBY 的开销太大 而 PHP 对一些二维三维数组排序貌似不是很友好?

谢谢各位

2585 次点击
所在节点    PHP
6 条回复
z5864703
2016-10-14 17:16:27 +08:00
哪怕分开查询,也可以做到不用 foreach 每个表去查。
可以参考 laravel 框架的 ORM 设计
solaro
2016-10-14 17:23:59 +08:00
php 中如果追求速度、效率,可以这么干:查出一个表的数据,然后丢给 php 变量,最后通过 php 的自身去拼凑数据。熟读会快很多,直接在 php 里 foreach 进行表查询,其实本质上是执行多了 N 次的数据库操作,如果不追求速度和效率可以这么干,写代码省事,如果要优化,最好别这么干
qqjt
2016-10-14 17:31:34 +08:00
请使用 laravel 框架,一次性解决你说的各种问题
zhangjieren
2016-10-14 17:35:00 +08:00
@qqjt 谢谢提醒 现在是一些老的项目的优化和改进,想知道如何优化会比较有效率。

@solaro 谢谢大大 请问下就是说 foreach 里面查询是肯定不可取的 那接着就剩下联表和您说的这个通过 PHP 的拼凑,这样的话是否开发上会有点不太友好(就是比较麻烦←,←)
mingyun
2016-10-15 00:00:22 +08:00
肯定不能在 foreach 查询,可以先查一个表的数据,然后用 in 查另外一个表,再映射下返回
msg7086
2016-10-15 13:16:51 +08:00
可以去看一下 ORM 的 N+1 问题。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/312817

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX