零点起飞学JavaWeb开发之Hibernate事务处理和缓存管理x

零点起飞学JavaWeb开发之Hibernate事务处理和缓存管理x

ID:38811285

大小:414.19 KB

页数:20页

时间:2019-06-19

零点起飞学JavaWeb开发之Hibernate事务处理和缓存管理x_第1页
零点起飞学JavaWeb开发之Hibernate事务处理和缓存管理x_第2页
零点起飞学JavaWeb开发之Hibernate事务处理和缓存管理x_第3页
零点起飞学JavaWeb开发之Hibernate事务处理和缓存管理x_第4页
零点起飞学JavaWeb开发之Hibernate事务处理和缓存管理x_第5页
资源描述:

《零点起飞学JavaWeb开发之Hibernate事务处理和缓存管理x》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、第16章Hibernate事务处理和缓存管理Hibernate提供了进行数据库事务处理、并发事务控制、缓存管理的方法。事务处理和缓存管理对于高效率地使用数据库是非常重要的。通过本章的学习,读者可以了解事务、并发事务的概念,以及如何使用Hibernate管理事务,如何管理Hibernate的缓存,从而在实际开发中很好地优化Hibernate的性能。16.1Hibernate的事务处理数据库事务是一个或者多个SQL语句组成的工作单元。如果有一个SQL语句执行失败,就必须撤销整个工作单元。在并发环境中,多个事务同时访问相同的数据资源,这样就可能造成各种并发问题。这时

2、可以通过设置数据库系统的事务隔离级别来避免各种并发问题。此外,在应用悲观锁来解决数据丢失这一并发问题。对于事务处理,Hibernate有自己进行事务处理的方法,本节通过实例来进行讲解。16.1.1什么是数据库事务下面介绍数据库事务的概念,以及它的特征。1.事务的概念事务是数据库操作中一个最小的执行单元,它由一组相互依赖的操作行为组成。例如,由查询和更新两个操作行为构成一个事务。事务的成功与否取决于这些操作行为是否都能执行成功。只要有一个操作行为执行失败,那么整个事务执行失败。这时必须回滚到事务执行前的状态。2.事务的特性数据库事务必须具有ACID特征,ACID

3、是Atomic(原子性)、Consistency(一致性)、Isolation(隔离性)和Durability(持久性)的英文缩写。下面解释这4个概念。原子性:是指整个数据库事务是一个不可分割的工作单元。一致性:是指事务不能破坏关系数据的完整性和业务逻辑上的一致性。隔离性:事务的隔离性要求事务访问的任何数据不会受到其他事务所做的任何改变的影响,直到该事务完成。持久性:是指只要事务成功结束,它对数据库所做的操作必须永久保存下来。即使系统发生崩溃,重新启动系统后,数据库还能恢复到事务成功结束时的状态。16.1.2数据库的隔离级别数据库的锁机制可以保证事务的隔离性,

4、避免多个事务同时对同一资源进行操作。但是当锁的数目太多时,会影响数据库的并发性能。并发性能是指数据库系统同时给各种访问者提供服务的能力。例如,当一个事务锁定某一个资源时,其他的事务必须停下来等待,这样就降低了数据库相应多个请求的速度。所以,为了能让用户根据实际需求,在事务的隔离性和并发性之间做出合理的权衡,数据库系统提供了4种事务隔离的级别供用户选择。1.Serializable(串行化)当数据库采用该级别进行隔离时,一个事务在执行的过程中完全看不到其他事务对数据库所做的更新。当两个事务同时访问同一资源时,如果一个事务已经开始访问该资源,则另一个事务必须停下来

5、等待,直到前一个事务结束。2.RepeatableRead(可重复读)当数据库采用这个级别进行隔离时,一个事务在执行的过程中可以看到其他事务已经提交的新插入的记录,但是看不到其他事务对已有记录的更新。3.ReadCommitted(读已提交数据)当数据库采用该隔离级别时,一个事务在执行的过程中可以看到其他事务已经提交的新插入的记录,并且可以看到其他事务已经提交的对已有记录的更改。4.ReadUncommitted(读未提交数据)当数据库采用该级别进行隔离时,一个事务在执行的过程中可以看到其他事务没有提交的新插入的记录,而且可以看到其他事务没有提交的对已有记录的

6、更新。16.1.3了解Hibernate中的事务处理Hibernate封装了JDBCAPI和JTAAPI,提供专门进行事务管理的类Transaction。使用它可以对事务进行管理。尽管程序员可以直接使用JDBCAPI进行事务管理,但是这样不利于进行跨平台开发。因而应该优先考虑使用Hibernate提供的API进行事务管理。16.1.4并发控制在并发环境中,一个数据库系统可能同时受到多个客户程序的访问。这些客户程序可能是数据库服务器的客户端、Java应用程序、也可能是Java应用程序中的不同线程。对于同时运行的多个事务,如果没有采用最高级别的隔离机制Serial

7、izable,而是使用低级的隔离机制,则可能会导致各种并发问题。16.2管理Hibernate缓存Hibernate有二级缓存结构。session缓存是内置的,被称为Hibernate的一级缓存;SessionFactory的外置缓存是可以插拔的缓存插件,它被称为Hibernate的二级缓存。Hibernate使用缓存策略去实现持久化对象和数据库的同步更新,并且缓存可以很大程度上提升查询的速度。本节先介绍缓存的基本原理,然后分别讲解如何使用Hibernate的二级缓存。16.2.1缓存的基本原理缓存的概念在计算机领域非常常见,它介于应用程序和永久性数据(如硬盘

8、文件、数据库)之间。它可以降低应用程序

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。