同时操作一个数据、同步数据要注意地方。

场景1:同时操作一个数据

比如用户管理模块,如果多个管理员可以同时操作一个用户,默认情况下,后面人的操作会覆盖前面人的修改。比如管理员1在2016/1/11 15:00 01,点击edit, 把user1这个用户的信息,在editUser界面把user1的Sex属性从男改成女了。管理员2在2016/1/11 15:00 02页点击edit,准备编辑user1的信息,只是eidtUser页面加载的是管理员1编辑之前的数据,性别是男,因为管理员1还没有提交。2016/1/11 15:00 03管理员1提交了修改。管理员2修改了籍贯字段,在2016/1/11 15:00 05也提交了,这时候,管理员2的操作将覆盖管理员1的操作,性别是被重置为女。

解决方案:

1.像SVN类似,数据库添加一个版本号,管理员2提交的时候,对比他当前加载的是不是最新的版本。如果不是,提醒他先获取最新的再修改。 这种方案也不是很完善,因为,1.管理员2可能操作半天了,难道放弃更改? 2.不能根本解决问题。

2.在存储过程中,第一个管理员操作时,加锁,其他管理员暂时不能对这个用户进行操作。 其他管理员要操作时候,先获取最新版本。

具体实现:

场景2:同步数据

支持离线模式的APP,需求是数据存放在客户端,只是登录的时候从服务器同步一次,当做好一些操作之前,post回服务器。

当服务器post回去的时候,需要检查是否是基于最新版本操作的,有什么差异,基于服务器最新版,有哪些工作需要继续做。

原文地址:https://www.cnblogs.com/sen068/p/5121377.html