1.4.1 Spring 的 JDBC 的模板:
1.4.1.1 Spring 提供了很多持久层技术的模板类简化编程:
spring中提供了一个可以操作数据库的对象.对象封装了jdbc技术.
JDBCTemplate => JDBC模板对象
与DBUtils中的QueryRunner非常相似.
Spring中JDBC模板的基本使用案例
①:创建数据库及表
②:引入相关jar包
③:编写测试类
此测试类中用到的连接池是c3p0,所以还需要导入c3p0的jar包
也可以用spring自带的连接池,如下图的测试类:
开发步骤
一:导包
①:4 + 2
com.springsource.org.apache.log4j-1.2.15.jar(可选)老版本的需要用到这个包
②:spring-text、spring-aop、junit4类库
③:c3p0连接池、jdbc驱动
④:spring-jdbc、spring-tx
二:准备数据库
三:编写User的bean类
四:编写UserDao接口
五:编写UserDao接口的实现类 UserDaoImpl 类
六:编写spring的配置文件applicationContext.xml
(如下图)
1:读取db.properties文件中的数据 xml中提供两种方式
2:UserDao接口的实现类 UserDaoImpl,没有继承JdbcDaoSupport则需在xml中配置JdbcTemplate类,并且在UserDaoImpl类中需要使用spring获取bean的方式获取JdbcTemplate对象来使用
七:编写测试类
1.4.2 Spring 中的aop事务:
1.4.2.1 什么是事务:
事务逻辑上的一组操作,组成这组操作的各个逻辑单元,要么一起成功,要么一起失败.
1.4.2.2 事务特性:
原子性 :强调事务的不可分割.
一致性 :事务的执行的前后数据的完整性保持一致.
隔离性 :一个事务执行的过程中,不应该受到其他事务的干扰
持久性 :事务一旦结束,数据就持久到数据库
1.4.2.3 如果不考虑隔离性引发安全性问题:
脏读 :一个事务读到了另一个事务的未提交的数据
不可重复读 :一个事务读到了另一个事务已经提交的 update 的数据导致多次查询结果不一致.
虚幻读 :一个事务读到了另一个事务已经提交的 insert 的数据导致多次查询结果不一致.
1.4.2.4 解决读问题:设置事务隔离级别
未提交读 :脏读,不可重复读,虚读都有可能发生
已提交读 :避免脏读。但是不可重复读和虚读有可能发生
可重复读 :避免脏读和不可重复读.但是虚读有可能发生.
串行化的 :避免以上所有读问题.
Mysql 默认:可重复读
Oracle 默认:读已提交
1.4.3 Spring 进行事务管理一组 API
1.4.3.1 PlatformTransactionManager:平台事务管理器.
***** 真正管理事务的对象
org.springframework.jdbc.datasource.DataSourceTransactionManager 使用 Spring JDBC 或 iBatis 进行持久化数据时使用
org.springframework.orm.hibernate3.HibernateTransactionManager 使用 Hibernate 版本进行持久化数据时使用
1.4.3.2 TransactionDefinition:事务定义信息
事务定义信息:
* 隔离级别
* 传播行为
* 超时信息
* 是否只读
1.4.3.3 TransactionStatus:事务的状态
记录事务的状态
1.4.3.4 Spring 的这组接口是如何进行事务管理:
平台事务管理根据事务定义的信息进行事务的管理,事务管理的过程中产生一些状态,将这些状态记 录到 TransactionStatus 里面1.4.3.5 事务的传播行为
PROPAGION_XXX :事务的传播行为
* 保证同一个事务中
PROPAGATION_REQUIRED 支持当前事务,如果不存在 就新建一个(默认) 工作中99%使用的是这种方式
PROPAGATION_SUPPORTS 支持当前事务,如果不存在,就不使用事务
PROPAGATION_MANDATORY 支持当前事务,如果不存在,抛出异常
* 保证没有在同一个事务中
PROPAGATION_REQUIRES_NEW 如果有事务存在,挂起当前事务,创建一个新的事务
PROPAGATION_NOT_SUPPORTED 以非事务方式运行,如果有事务存在,挂起当前事务
PROPAGATION_NEVER 以非事务方式运行,如果有事务存在,抛出异常PROPAGATION_NESTED 如果当前事务存在,则嵌套事务执行
Spring管理事务方式(案例讲解)
描述事务---转账案例
两种方式:编码式(了解)、xml配置aop方式
编码式(了解):步骤如下
①导包:
②:编写Dao的接口与Service的接口
dao的接口
service的接口
③:数据库准备
④:接口的实现类
dao接口的实现类
service接口的实现类
⑤:applicationContext.xml的配置
⑥:编写测试类
接下来运行测试类后,发现数据库中的钱进行转账成功,若转账中出现异常,转账钱数不会进行改变。
xml配置AOP的方式:步骤如下
①导包:
②:编写Dao的接口与Service的接口
dao的接口
service的接口
③:数据库准备
④:接口的实现类
dao接口的实现类
service接口的实现类
⑤:applicationContext.xml的配置
⑥:编写测试类