搜索

首页  >  问答  >  正文

node.js - 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字段从数据库读取旧的。不过当数据表有几十个字段的时候,这样,程序略显烦琐。

请问你们是如何解决的?

ringa_leeringa_lee2732 天前566

全部回复(1)我来回复

  • 天蓬老师

    天蓬老师2017-06-05 11:14:48

    典型的事务问题。

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

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

    回复
    0
  • 取消回复