nodejs 多线程 如何解决数据一致的问题

试想有这么一个场景。比如一张 test表,里面有字段

count:0
name:'abc'

当用户打开一个编辑界面的时候,从数据库里面读取的数据是

count:3
name:'abc'

然后他改了一个name,变成了这样

count:3
name:'efg'

此时此刻,这个test表,其他程序在高速的读写。因为用户还没保存数据到数据表,其他程序保存的数据就是

count:40
name:'abc'

不断的改变count字段,变成41、42、43,此时用户修改完毕,保存数据到数据库,此时保存的最终数据是

count:3
name:'efg'

然后问题就出来了。。。count字段数据有问题了。

如何解决这个问题?

1、要么把count字段分开到另外一个表,然后两个表关联起来,互不干扰。不过这样数据读的时候需要读两个表,有点麻烦了。

2、用户保存数据的时候,只更新必要的字段。比如count字段从数据库读取旧的。不过当数据表有几十个字段的时候,这样,程序略显烦琐。

请问你们是如何解决的?

阅读 2.9k
1 个回答

典型的事务问题。

你用的什么数据库?学过事务吗?去学学你使用的数据库如何支持事务的。

简单说就是:给数据加锁,使同一时间只能有一个client做读写操作,其它client都得等着。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题