JAVA_WEB Spring框架学习 第三章 spring整合JDBC、spring中的aop事物

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的配置

                        


                                ⑥:编写测试类

                        

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

晓 5

有啥不懂的可以单聊解答....

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值