(1)硬件环境不同:
C/S一般建立在专用的网络上,小范围里的网络环境,局域网之间
再通过专门服务器提供链接和数据交换服务。
B/S建立在广域网之上,不必是专门的网络硬件环境,有比C/S更强的适应范围,
一般只要有操作系统和浏览器就行。
当出现多个用户同时执行更新等操作时,会出现事务交叉更新操作的冲突,会破坏业务和数据的完整性。可以使用悲观锁和乐观锁解决这类问题。
a.
悲观锁机制:在进行数据查询时追加一个锁机制,进行业务操作,此时其他用户不能进行增删改操作,在事务结束时会自动将锁释放,其他用户可以继续执行此类操作。
悲观锁特点:将用户操作一个一个处理,可以解决更新并发问题,缺点是处理效率比较低。
b.乐观锁机制:多个不同用户都可以同时对数据库记录进行查看和更新操作,但是最先commit提交的用户会执行成功,后续用户会以异常形式提示失败。
乐观锁是借助于一个版本字段进行控制,当并发操作中一个用户成功提交了,版本字段值会自动加
乐观锁特点:允许多个用户同时操作,处理效率相对较高。
乐观所使用步骤:
–将原有数据表追加一列版本字段,初始值0
–在实体类中添加版本属性
–在映射描述文件中采用元素定义版本属性和版本字段的映射
–当发生多个事务并行交叉执行时,第一个提交的成功,后续提交的会抛出异常。可以异常捕获给用户一个友善的提示。