菜鸟求助,怎么解决并发问题

2019-10-20 11:06:28 +08:00
 hhh798

这样一个场景 文章表有个点赞数字段,每当有人点赞就将点赞数+1,但是多人同时点就会导致,表里的点赞数小于实际点赞次数。这种应该如何处理呢

3630 次点击
所在节点    程序员
30 条回复
iPhoneXI
2019-10-20 16:39:55 +08:00
@nioncodotcom 不就是一条 SQL 的事
hhh798
2019-10-20 17:06:41 +08:00
@iPhoneXI
post 表点赞字段是 applause_count, SQL 这么写:update post set applause_count=applause_count+1 where id=XX?
iPhoneXI
2019-10-20 17:40:49 +08:00
@nioncodotcom 我觉得这么写没啥问题
mingmeng
2019-10-20 18:09:19 +08:00
@nioncodotcom 你是先查出来结果,添加之后再入库?这样不就构成了脏数据么。。。
ech0x
2019-10-20 18:12:51 +08:00
@nioncodotcom 对啊,就是这样写啊……不然呢。
ech0x
2019-10-20 18:19:07 +08:00
@nioncodotcom 你先读再 update 就得自己维持原子性了。
hhh798
2019-10-20 19:55:44 +08:00
@ech0x @iPhoneXI 了解了,感谢
@mingmeng 这就是脏数据啊,长知识了。。
mingmeng
2019-10-20 21:05:05 +08:00
@nioncodotcom 该补一下课了,数据库 ACID 原子性,一致性,隔离性,持久性~
Kontinue
2019-10-21 08:41:26 +08:00
楼上说的都对,根据方案可以再去搜对应的博客。
当前前提得看你的并发量不是?如果仅仅只是考虑到这个问题或并发量不大,直接 update 乐观锁搞定(毕竟编码简单),并发量高的才考虑设计使用队列 redis etc.
Raymon111111
2019-10-21 12:42:14 +08:00
如果是只要数量的话用 redis ++ 就可以了

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

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

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

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

© 2021 V2EX