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