数据库的连接与断开时间开销很大吗?

2018-11-07 13:33:51 +08:00
 chaleaochexist
一个 api 需要查询数据库 1400 多次.
想把他们捏到一个或几个 sql 里面.

这样的话可能需要连 N(5-10)张表查询.也就是说,将压力推给了数据库.这样的方式可行吗?

每个表的记录数量都不大.几千条记录.

1400 个查询,大概耗时 10 秒.
2499 次点击
所在节点    程序员
9 条回复
sujin190
2018-11-07 13:57:23 +08:00
连接断开确实开销很大,但是一般是复用连接查多次,join 需要临时表太消耗数据库 cpu 了,最好还是不要连接太多表
sutra
2018-11-07 14:00:38 +08:00
所以出现了连接池技术吧。
TomVista
2018-11-07 14:21:14 +08:00
完全可以,
不过我很好奇什么东西需要 1400 多次数据库查询,你确定业务没问题吗?
另外你确定你的后端 分离了数据存储服务吗?
no1xsyzy
2018-11-07 15:20:55 +08:00
连表一般问题不大
只要 sql 不瞎写(不需要的不取,多连也没关系,无关的话连接会自动优化消失的),不管连表还是多次查询差不了多少的,连表有消耗,传递语句和结果也有消耗,口头估算不用考虑
除非你在 sql 语句里做运算,那个不是 sql 专长
具体先 perf 再决定。也可以 explain 一下再优化点。
no1xsyzy
2018-11-07 15:22:32 +08:00
我不清楚能不能先 prepare 了再多次查询,那个其实效率挺好的,只做一次预处理。
甚至出现过单次查询都是 prepare 效率更高的情况
luozic
2018-11-07 15:42:26 +08:00
這種數據是實時的還是可以緩存的,可以緩存的直接上緩存和更新緩存。不過你這需要查 1400 多次的,設計確定沒問題?
jydeng
2018-11-07 15:54:58 +08:00
一直不断建立连接很耗费性能,连表还好。
mmdsun
2018-11-07 19:22:09 +08:00
MySQL 设计是轻量级连接开销不大
feverzsj
2018-11-07 19:26:16 +08:00
才这么点数据,你全都读到本地不就好了

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

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

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

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

© 2021 V2EX