免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 6888 | 回复: 15
打印 上一主题 下一主题

[其他] 多线程/多进程更新数据库的问题 [复制链接]

论坛徽章:
1
黑曼巴
日期:2020-02-27 22:54:26
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-10-19 18:49 |只看该作者 |倒序浏览
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
324
射手座
日期:2013-08-23 12:04:38射手座
日期:2013-08-23 16:18:12未羊
日期:2013-08-30 14:33:15水瓶座
日期:2013-09-02 16:44:31摩羯座
日期:2013-09-25 09:33:52双子座
日期:2013-09-26 12:21:10金牛座
日期:2013-10-14 09:08:49申猴
日期:2013-10-16 13:09:43子鼠
日期:2013-10-17 23:23:19射手座
日期:2013-10-18 13:00:27金牛座
日期:2013-10-18 15:47:57午马
日期:2013-10-18 21:43:38
2 [报告]
发表于 2013-10-19 19:47 |只看该作者
不需要      

论坛徽章:
15
射手座
日期:2014-11-29 19:22:4915-16赛季CBA联赛之青岛
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16赛季CBA联赛之四川
日期:2017-02-07 21:08:572015年亚冠纪念徽章
日期:2015-11-06 12:31:58每日论坛发贴之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-07-12 22:20:002015亚冠之浦和红钻
日期:2015-07-08 10:10:132015亚冠之大阪钢巴
日期:2015-06-29 11:21:122015亚冠之广州恒大
日期:2015-05-22 21:55:412015年亚洲杯之伊朗
日期:2015-04-10 16:28:25
3 [报告]
发表于 2013-10-19 19:53 |只看该作者
c/unix 发表于 2013-10-19 18:49
请教1个问题,一般的数据库,比如oracle,mysql等
有多个进程或者线程并发,执行命令更新1个表的1个记录, ...

在所有进/线程完成后,值被加了n。

论坛徽章:
13
双鱼座
日期:2013-10-23 09:30:05数据库技术版块每日发帖之星
日期:2016-04-20 06:20:00程序设计版块每日发帖之星
日期:2016-03-09 06:20:002015亚冠之塔什干火车头
日期:2015-11-02 10:07:452015亚冠之德黑兰石油
日期:2015-08-30 10:07:07数据库技术版块每日发帖之星
日期:2015-08-28 06:20:00数据库技术版块每日发帖之星
日期:2015-08-05 06:20:002015年迎新春徽章
日期:2015-03-04 09:57:09辰龙
日期:2014-12-03 14:45:52酉鸡
日期:2014-07-23 09:46:23亥猪
日期:2014-03-13 08:46:22金牛座
日期:2014-02-11 09:36:21
4 [报告]
发表于 2013-10-19 21:04 |只看该作者
正确的,mysql本身对这方面有考虑

论坛徽章:
6
酉鸡
日期:2013-10-18 21:53:40射手座
日期:2013-10-26 19:40:18技术图书徽章
日期:2013-10-26 20:39:15巳蛇
日期:2013-10-26 22:13:11狮子座
日期:2013-11-02 16:45:58水瓶座
日期:2013-11-04 07:42:19
5 [报告]
发表于 2013-10-20 08:21 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
6 [报告]
发表于 2013-10-20 09:03 |只看该作者
ls的有空倒不如好好回答lz的问题。
数据库本身有相应的处理,但是不同的引擎会有不同的设计,比如MyISAM和InnoDB所分别提供的锁定粒度就不一样。
具体可以查一下这方面的文档。

论坛徽章:
6
酉鸡
日期:2013-10-18 21:53:40射手座
日期:2013-10-26 19:40:18技术图书徽章
日期:2013-10-26 20:39:15巳蛇
日期:2013-10-26 22:13:11狮子座
日期:2013-11-02 16:45:58水瓶座
日期:2013-11-04 07:42:19
7 [报告]
发表于 2013-10-20 09:10 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
6
酉鸡
日期:2013-10-18 21:53:40射手座
日期:2013-10-26 19:40:18技术图书徽章
日期:2013-10-26 20:39:15巳蛇
日期:2013-10-26 22:13:11狮子座
日期:2013-11-02 16:45:58水瓶座
日期:2013-11-04 07:42:19
8 [报告]
发表于 2013-10-20 09:13 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
6
酉鸡
日期:2013-10-18 21:53:40射手座
日期:2013-10-26 19:40:18技术图书徽章
日期:2013-10-26 20:39:15巳蛇
日期:2013-10-26 22:13:11狮子座
日期:2013-11-02 16:45:58水瓶座
日期:2013-11-04 07:42:19
9 [报告]
发表于 2013-10-20 09:32 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
10 [报告]
发表于 2013-10-20 20:06 |只看该作者
本帖最后由 linux_c_py_php 于 2013-10-20 20:07 编辑

update table set value = value + 1

这样的语句是原子的, 但是调用者不清楚自己到底完成了"几+1=几", 只知道"+1".

如果调用者想知道自己完成了"几+1=几":

1, 一种方式是DB事务, 这是一定可以完成的, 相当于DB中的锁.
2, 另一种方法是活锁, 就是不使用事务, 先select得到一个value, 然后update set name=value+1 where name=value; 这样保证只有一个人更新成功, 对于DB来说很友好.  一般你要做个秒杀活动之类的, 这种做法刚好适合业务场景.
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP