试想有这么一个场景。比如一张 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字段从数据库读取旧的。不过当数据表有几十个字段的时候,这样,程序略显烦琐。
请问你们是如何解决的?
天蓬老师2017-06-05 11:14:48
典型的事务问题。
你用的什么数据库?学过事务吗?去学学你使用的数据库如何支持事务的。
简单说就是:给数据加锁,使同一时间只能有一个client做读写操作,其它client都得等着。