文章详情页
mysql - 循环中逐个查询数据库和联表一次性查询数据库分别适用于哪种场景?
浏览:156日期:2022-06-20 16:31:04
问题描述
一般来说循环中逐条查询的效率是比较低的,每次都产生连接以及并发的开销。是否有些场景是适合在循环中逐个去查询,而不适合一次性查表的场景呢?
问题解答
回答1:不要在循环中去查询, 看不到任何在适合在循环中查询的理由!如果你是一个离线任务, 不用像web请求那样即时返回, 并且数据量也比较大, 那合理的做法也是你对查询做一定的切割, 每次获取几十到几百的数据(过多的数据也会导致传输缓慢)最后, 即使迫不得已真的要在循环中去查询了, 你也应该使用同一个连接, 而不是每次都重新建立连接!
回答2:有,例如:
SELECT * FROM tableWHERE ...ORDER BY ..LIMIT 10
这种时候如果WHERE条件有若干个(例如id=1,id=2),就只能分开查了。虽然GROUP BY也可以,但GROUP BY在数据量大的时候性能可能比较低,一次GROUP BY查询的时长可能比分开多次查询的时间还要长。
相关文章:
1. python - 求一个在def中可以实现调用本def满足特定条件continue效果的方法(标题说不太清楚,请见题内描述)2. MYSQL新建用户设置可以远程访问的问题3. $fields = $values = [];这条代码一直定义不了,一直报错,老师的源码也是被报错的,执行不了,请问该怎么解决这个问题4. java - mybatis怎么实现在数据库中有就修改,没有就添加5. node.js - nodejs和前端JavaScript 字符串处理结果不一样是什么原因?6. linux - 为什么我在mysql的my.cnf下找不到bind-address?7. 数据库设计 - MySQL数据库主键问题8. mysql同步数据到elasticsearch用什么工具?9. mysql 5.7单表300万数据,性能严重下降,如何破?10. 数据库 - mysql 远程可以连接,但是本地连接拒绝?
排行榜
![$fields = $values = [];这条代码一直定义不了,一直报错,老师的源码也是被报错的,执行不了,请问该怎么解决这个问题](http://www.haobala.com/attached/image/news/202205/093622cb60.png)