1.Spring事务管理简化了传统的数据库的事务管理流程,提高了效率
2.Spring的数据库编程
Spring框架为开发者提供了JDBC模板模式,即jdbcTemple,简化了很多代码,但比较常用的是MyBatis框架或者Hibernate框架
Spring JDBC的配置
主要使用Spring JDBC模块的core 和 dataSource包
core是JDBC的核心功能包,包括Jdbc Template类,dataSource包是访问数据源的工具类包
Spring JDBC操作数据库的配置文件如下:
<!-- 配置数据源 -->
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<!-- MySQL数据库驱动 -->
<property name="driverClassName" value="com.mysql.cj.jdbc.Driver"/>
<!-- 连接数据库的URL -->
<property name="url" value="jdbc:mysql://localhost:3306/数据库名称?characterEncoding=utf8&serverTimezone=UTC"/>
<!-- 连接数据库的用户名 -->
<property name="username" value="root"/>
<!-- 连接数据库的密码 -->
<property name="password" value="123456"/>
</bean>
<!-- 配置JDBC模板 -->
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
<property name="dataSource" ref="dataSource"/>
</bean>
在数据访问层需要使用jdbcTemplate时需要将jdbcTemplate注入到对应的Bean中
@AutoWired
//使用配置文件中的JDBC模板
private JdbcTemplate jdbcTemplate;
Spring JdbcTemplate常用方法:update、query
public int update(String sql,Object args[]):对数据表进行增加、修改、删除等功能
String insertsql="insert into user values(null,?,?)";
Object param1[]={"chenheng1","男"};
jdbcTemplate.update(sql,param1);
public List<T> query(String sql,RowMapper<T>rowMapper,Object args[]):对数据表进行查询操作
rowMapper将结果集映射到用户自定义的类中(前提时自定义类中的属性要与数据表的字段对应)
String selectSql = "select * from user";
RowMapper<MyUser> rowMapper = new BeanPropertyRowMapper<MyUser>(MyUser.class);
List<MyUser> list = jdbcTemplate.query(sql,rowMapper,null);
3.编程式事务管理
在代码中显示调用beginTransaction、commit、rollback等与事务处理相关的方法(适用于少数实事务操作)
基于底层API的编程式事务管理:
根据PlatformTranscationManager、TransactionDefinition和TransactionStatus几个核心接口,通过编程的方式来进行事务处理
具体步骤:
a.给数据源配置事务管理器:具体代码如下
b.创建数据访问类(可使用@Repository进行注解)
c.创建测试类
基于TransactionTemplate的编程式事务管理:
4.声明式事务管理
声明式事务管理:通过AOP技术实现的事务管理,本质是对方法前后进行拦截,然后在目标方法开始之前创建或者加入一个事务,在执行完目标方法之后根据执行情况提交或者回滚事务。
最大优点:不需要通过编程的方式管理事务,代码相对简洁较易维护
不足之处:最细粒度职能作用到方法级别,无法做到像编程式事务管理作用到代码块级别(可以通过将需要进行事务处理的代码块独立为方法)
两种方法实现:基于XML的方式;基于@Transactional注解的方式
基于XML方式的声明式事务管理
通过在配置文件中配置事务规则的相关声明来实现
Spring提供了tx命名空间来配置事务,提供了<tx:advice>元素来配置事务的通知(需要指定id和transaction-manager属性,其中id属性式配置文件中的唯一标识,transcation-manager属性指定事务管理器),其<tx:attributes>子元素,可配置多个<tx:method>子元素指定执行事物的细节
在<tx:advice>元素配置了事务的增强处理就可以通过编写AOP配置让Spring自动对目标对象生成代理
基于@Transactional注解的声明式事务管理
@Transactional注解可以作用于接口、接口方法、类以及类的方法上,当作用于类上时,该类的所有public方法都将具有该类型的事务属性,同时也可以在方法级别使用该注解来覆盖类级别的定义