81、SimpleJdbcTemplate
SimpleJdbcTemplate类也是基于JdbcTemplate类,但利用Java5+的可变參数列表和自己主动装箱和拆箱从而获取更简洁的代码。
SimpleJdbcTemplate主要提供两类方法:query及queryForXXX方法、update及batchUpdate方法。
82、集成Spring JDBC及最佳实践
大多数情况下Spring JDBC都是与IOC容器一起使用。通过配置方式使用Spring JDBC。 并且大部分时间都是使用JdbcTemplate类(或SimpleJdbcTemplate和NamedParameterJdbcTemplate)进行开发。就可以能80%时间使用JdbcTemplate类,而仅仅有20%时间使用其它类开发,符合80/20法则。
Spring JDBC通过实现DaoSupport来支持一致的数据库訪问。SpringJDBC提供例如以下DaoSupport实现:
JdbcDaoSupport:用于支持一致的JdbcTemplate訪问。
NamedParameterJdbcDaoSupport:继承JdbcDaoSupport,同一时候提供NamedParameterJdbcTemplate訪问;
SimpleJdbcDaoSupport:继承JdbcDaoSupport,同一时候提供SimpleJdbcTemplate訪问。
因为JdbcTemplate、NamedParameterJdbcTemplate、SimpleJdbcTemplate类使用DataSourceUtils获取及释放连接,并且连接是与线程绑定的,因此这些JDBC模板类是线程安全的。即JdbcTemplate对象能够在多线程中重用。
83、Spring对ORM的支持
Spring对ORM的支持主要表如今下面方面:
一致的异常体系结构,对第三方ORM框架抛出的专有异常进行包装。从而在使我们在Spring中仅仅看到DataAccessException异常体系。
一致的DAO抽象支持:提供类似与JdbcSupport的DAO支持类HibernateDaoSupport。使用HibernateTemplate模板类来简化经常使用操作。HibernateTemplate提供回调接口来支持复杂操作;
Spring事务管理:Spring对全部数据訪问提供一致的事务管理,通过配置方式,简化事务管理。
Spring还在測试、数据源管理方面提供支持,从而同意方便測试。简化数据源使用。
84、标准SQL规范中定义了四种隔离级别:
未提交读(ReadUncommitted):最低隔离级别。一个事务能读取到别的事务未提交的更新数据,非常不安全。可能出现丢失更新、脏读、不可反复读、幻读。
提交读(ReadCommitted):一个事务能读取到别的事务提交的更新数据,不能看到未提交的更新数据,不可能可能出现丢失更新、脏读。但可能出现不可反复读、幻读;
可反复读(RepeatableRead):保证同一事务中先后运行的多次查询将返回同一结果,不受其它事务影响。可能可能出现丢失更新、脏读、不可反复读,但可能出现幻读。
序列化(Serializable):最高隔离级别。不同意事务并发运行,而必须串行化运行,最安全。不可能出现更新、脏读、不可反复读、幻读。
隔离级别越高。数据库事务并发运行性能越差。能处理的操作越少。
因此在实际项目开发中为了考虑并发性能一般使用提交读隔离级别,它能避免丢失更新和脏读,虽然不可反复读和幻读不能避免,但能够在可能出现的场合使用悲观锁或乐观锁来解决这些问题。
85、数据库事务类型
数据库事务类型有本地事务和分布式事务:
本地事务:就是普通事务,能保证单台数据库上的操作的ACID,被限定在一台数据库上。
分布式事务:涉及两个或多个数据库源的事务。即跨越多台同类或异类数据库的事务(由每台数据库的本地事务组成的)。分布式事务旨在保证这些本地事务的全部操作的ACID,使事务能够跨越多台数据库;
86、Java事务类型
Java事务类型有JDBC事务和JTA事务:
JDBC事务:就是数据库事务类型中的本地事务,通过Connection对象的控制来管理事务;
JTA事务:JTA指Java事务API(Java TransactionAPI),是Java EE数据库事务规范。 JTA仅仅提供了事务管理接口。由应用程序server厂商(如WebSphere Application Server)提供实现,JTA事务比JDBC更强大,支持分布式事务。
87、Java EE事务类型
Java EE事务类型有本地事务和全局事务:
本地事务:使用JDBC编程实现事务;
全局事务:由应用程序server提供,使用JTA事务;
88、按是否通过编程实现事务
按是否通过编程实现事务有声明式事务和编程式事务;
声明式事务: 通过注解或XML配置文件指定事务信息;
编程式事务:通过编写代码实现事务。
89、Spring提供的事务管理
Spring框架最核心功能之中的一个就是事务管理,并且提供一致的事务管理抽象,这能帮助我们:
提供一致的编程式事务管理API,无论使用Spring JDBC框架还是集成第三方框架使用该API进行事务编程;
无侵入式的声明式事务支持。
Spring支持声明式事务和编程式事务事务类型。
90、Spring对编程式事务的支持
Spring中的事务分为物理事务和逻辑事务。
物理事务:就是底层数据库提供的事务支持,如JDBC或JTA提供的事务;
逻辑事务:是Spring管理的事务。不同于物理事务,逻辑事务提供更丰富的控制,并且假设想得到Spring事务管理的优点,必须使用逻辑事务,因此在Spring中假设没特别强调一般就是逻辑事务;
逻辑事务即支持很低级别的控制。也有高级别解决方式:
低级别解决方式
工具类:使用工具类获取连接(会话)和释放连接(会话),如使用org.springframework.jdbc.datasource包中的ConnectionUtils类来获取和释放具有逻辑事务功能的连接。
当然对集成第三方ORM框架也提供了类似的工具类,如对Hibernate提供了SessionFactoryUtils工具类,JPA的EntityManagerFactoryUtils等,其它工具类都是使用类似***Utils命名;
//获取具有Spring事务(逻辑事务)管理功能的连接
DataSourceUtils.getConnection(DataSource dataSource)
//释放具有Spring事务(逻辑事务)管理功能的连接
DataSourceUtils.releaseConnection(Connection con, DataSource)
TransactionAwareDataSourceProxy:使用该数据源代理类包装须要Spring事务管理支持的数据源,该包装类必须位于最外层,主要用于遗留项目中可能直接使用数据源获取连接和释放连接支持或希望在Spring中进行混合使用各种持久化框架时使用。其内部实际使用ConnectionUtils工具类获取和释放真正连接。
<!--使用该方式包装数据源。必须在最外层,targetDataSource 知道目标数据源-->
<bean id="dataSourceProxy" class="org.springframework.jdbc.datasource.TransactionAwareDataSourceProxy">
<property name="targetDataSource" ref="dataSource"/>
</bean>
通过如上方式包装数据源后,能够在项目中使用物理事务编码的方式来获得逻辑事务的支持。即支持直接从DataSource获取连接和释放连接,且这些连接自己主动支持Spring逻辑事务;
高级别解决方式
模板类:使用Spring提供的模板类。如JdbcTemplate、HibernateTemplate和JpaTemplate模板类等,而这些模板类内部事实上是使用了低级别解决方式中的工具类来管理连接或会话。
Spring提供两种编程式事务支持:直接使用PlatformTransactionManager实现和使用TransactionTemplate模板类,用于支持逻辑事务管理。假设採用编程式事务推荐使用TransactionTemplate模板类和高级别解决方式。