软件开发者面试百问-----在Web应用中,你怎样避免几个人编辑同一段数据所造成的冲突?

在Web应用中,你怎样避免几个人编辑同一段数据所造成的冲突?
多人编辑同一条数据的情况应该是比较多的,为了避免出现数据不一致的情况,
我们需要想办法避免这样的情况(聒噪结束)
一般有下面两个办法:
1。编辑前加锁(悲观锁)
2。编辑后提醒(乐观锁)
对于第一种方法,就是在当前用户编辑数据初始化之前,判断当前数据是不是已经被别人锁定。如果已经被锁定,那么提醒用户,当前数据被其他人编辑,并且让页面只读。如果没有其他人编辑,那么系统锁定当前数据。要实现这样的功能,可以在数据库里添加两个字段:是否被锁定,锁定用户
这样做的好处是编辑的时候就可以让当前用户知道已经被别人锁定,避免在编辑之后才提醒,使用户做无用功。
这样做的缺点就是数据解锁比较麻烦,就是用户退出编辑的方式有很多种,比如直接关闭页面,那么这样的话,他就锁定了数据而没有释放。这样的话,可以做一个解锁的页面让管理员使用。或者在系统关闭的时段,执行批处理来解锁。
这个办法感觉用在同一条数据被多个人同时编辑的可能性比较大的时候使用。
2。编辑后提醒
就是允许多个人同时编辑,谁先提交谁生效。可以在数据库里设置一个字段叫做lastModifyTime(时间戳类型),编辑之前获得这个时间,提交的时候比较这个时间,如果相等则允许更新,如果不相等则提示用户,已经被别人编辑过,请重新载入数据。hibernate就支持这样的功能。
这样做的好处是实现简单,坏处就是会让用户做无用功。比如填了很多数据你告诉他别人捷足先登了,他肯定在心里骂%—%……%—%¥#¥。
所以这样的办法适合用在被多人同时编辑的可能性比较小的情况。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值