为什么很多人连基础的 SQL 都写不好,却开口闭口就是缓存架构分布式?

2021-09-02 18:35:48 +08:00
 wh469012917

说下情况,我们公司同个部门的好几个同事,连个基础的 SQL 都写不好,代码中一堆数据库 N+1 的问题,连个 WHERE IN 查询都不会用,涉及到批量查询,都是遍历然后一条条的去跑 SQL,同一个方法重复查询了好几次,数据库设计更是不行,外键都是用逗号分隔拼接成字符串,然后保存到主表上。

正因为 SQL 写的烂,所以接口性能很差劲,但是他们好像都不在意这些 IO 方面的优化,整天在想着怎么优化语言性能,比如反射、JSON 序列化、语言基础库的性能;要么就是上集群、加缓存,然后又没有任何设计模式,直接业务代码中强硬加入缓存读写,就算是缓存也是先从缓存读出数据,然后遍历一条条去数据库再查出来,性能更差了

其实整体项目量不大,好好写好 SQL,基本上能搞定 90% 的性能问题了,大部分的开发经验也都好几年了,不至于这种基础知识点不懂,可为啥就是不重视 SQL 性能

17916 次点击
所在节点    程序员
206 条回复
wh469012917
2021-09-03 09:24:06 +08:00
@opengps 对的,分布式微服务架构,是一把利剑,但其实大部分中小应用都用不到,单体应用一把梭了
wh469012917
2021-09-03 09:27:52 +08:00
@yanzhiling2001 可以去学习一下 mysql,都说 IO 是 Web 应用的性能瓶颈,而 SQL 查询是 IO 最重的地方,优化一条慢查询,比你做什么集群分布式都好用
xinJang
2021-09-03 09:29:52 +08:00
@wh469012917 这种应该直接关联表查询,子查询 count 吧
wh469012917
2021-09-03 09:31:00 +08:00
@xinJang 对的,关联查询一条 SQL 就能搞定了,按照遍历的方式,列表越长执行的 SQL 数越多
wangyzj
2021-09-03 09:37:31 +08:00
会做不如会叫
叫得好听肯定更容易被喜欢
xinJang
2021-09-03 09:46:24 +08:00
@wh469012917 这里我想引申一个问题。就是最近有个项目用得 spring boot,orm 框架是 jpa 。这里关联查询出来的数据,关联表的字段没法映射到实体类,网上没找到好的解决方式,这种有遇过么?
final7genesis
2021-09-03 10:34:03 +08:00
@wh469012917 第一次就把系统做好了,没有优化空间,系统上线没问题,然后老板把研发开了,留下几个运维人员
zhuzhibin
2021-09-03 10:34:27 +08:00
习惯就好 动不动就分布式、高并发、微服务 我身边也很多这种人,他们可能仅仅是看了一篇文章,就开始吹,各种熟悉 xxx,问起来或者动起手来,就尬住。
lizhenda
2021-09-03 10:47:03 +08:00
其实就是不会不重视不想学
wh469012917
2021-09-03 10:48:19 +08:00
@zhuzhibin 我们每天访问量不大,也就百万级别,而且并发不高,写好 sql 其实可以解决大部分问题了
wh469012917
2021-09-03 10:49:20 +08:00
@lizhenda 差不多这个意思,学起来不难,就是不想去学,能用就行
stach
2021-09-03 11:08:49 +08:00
楼主说的有道理, 不过单看你举的那个例子, 如果 `用户发表的动态数量` 这个表很大的话 (上千万), 你同事做的并没有问题.
stach
2021-09-03 11:11:02 +08:00
更好的做法是, 设计一张独立的用户统计表, 把 `动态数` 存起来, 单独维护, 这样就可以批量查询用户的动态数量了.
Latin
2021-09-03 11:21:15 +08:00
同事:你在教我做事啊! (狗头
offswitch
2021-09-03 11:43:08 +08:00
@wh469012917 join 确实难用,就你说的这个,list 估计也不大,像 count 可以优化一下,改成读缓存。
summerLast
2021-09-03 11:50:08 +08:00
@xinJang @Formula 看看这个注解
chendy
2021-09-03 11:54:53 +08:00
因为这种操作更容易让外人觉得自己很厉害,更容易找到吹逼的资本然后找下家
深耕业务各种优化也可以,但是要注意自己做记录做统计,因为不懂的人真的不知道你在干啥
thtznet
2021-09-03 12:42:30 +08:00
国内风气如此,不加点新名词怎么显得高级(华为别骂我)? SQL 用来几十年太成熟了,爆点不好搞出来嘛。
wh469012917
2021-09-03 12:50:28 +08:00
@stach 我是为了避嫌,所以假设了一个业务场景,而且下文也说了,数量级不大,单表最多也不过 2000w,过早的优化是万恶之源,只要写好 sql,基本上 ok
wh469012917
2021-09-03 12:51:06 +08:00
@offswitch join 不难用,只是心里害怕罢了;读缓存如何保证数据一致性呢?

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

https://tanronggui.xyz/t/799533

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

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

© 2021 V2EX