设为首页 加入收藏

TOP

14、Spring之基于注解的声明式事务(一)
2023-09-09 10:25:58 】 浏览:65
Tags:Spring 于注解 明式事

14.1、概述

14.1.1、编程式事务

事务功能的相关操作全部通过自己编写代码来实现:

Connection conn = ...;

try {

// 开启事务:关闭事务的自动提交
conn.setAutoCommit(false);

// 核心操作

// 提交事务
conn.commit();

}catch(Exception e){

// 回滚事务
conn.rollBack();

}finally{

// 释放数据库连接
conn.close();

}

编程式事务的缺陷:

  • 细节没有被屏蔽:所有细节都需要程序员自己来完成,比较繁琐。

  • 代码复用性不高:每次实现功能都需要自己编写代码,代码没有得到复用。

14.1.2、声明式事务

因为事务控制的代码有规律可循,代码的结构基本是确定的;所以框架就可以将固定模式的代码抽取出来,并进行相关的封装。

封装起来后,我们只需要在配置文件中进行简单的配置即可完成操作。

声明式事务的优点:

  • 提高开发效率

  • 消除了冗余的代码

  • 框架考虑和实现功能会更加全面

14.1.3、总结

  • 编程式:自己写代码实现功能

  • 声明式:通过配置让框架实现功能

14.2、环境搭建

创建名为spring_transaction的新module,过程参考13.1节

14.2.1、创建Spring的配置文件

image

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context https://www.springframework.org/schema/context/spring-context.xsd">

    <!-- 导入外部属性文件 -->
    <context:property-placeholder location="jdbc.properties"></context:property-placeholder>

    <!-- 配置数据源 -->
    <bean id="datasource" class="com.alibaba.druid.pool.DruidDataSource">
        <!--通过${key}的方式访问外部属性文件的value-->
        <property name="driverClassName" value="${jdbc.driver}"></property>
        <property name="url" value="${jdbc.url}"></property>
        <property name="username" value="${jdbc.username}"></property>
        <property name="password" value="${jdbc.password}"></property>
    </bean>

    <!-- 配置 JdbcTemplate -->
    <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
        <!-- 装配数据源 -->
        <property name="dataSource" ref="datasource"></property>
    </bean>

</beans>

14.2.2、创建表并填充数据

CREATE TABLE `t_book` (
`book_id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键',
`book_name` varchar(20) DEFAULT NULL COMMENT '图书名称',
`price` int(11) DEFAULT NULL COMMENT '价格',
`stock` int(10) unsigned DEFAULT NULL COMMENT '库存(无符号)',
PRIMARY KEY (`book_id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;

注意:该表的库存(stock)字段已设置为不能是负数(unsigned)

insert into `t_book`(`book_id`,`book_name`,`price`,`stock`) values (1,'斗破苍穹',80,100),(2,'斗罗大陆',50,100);

image

++++++++++++++++++++++++++++++分割线++++++++++++++++++++++++++++++

CREATE TABLE `t_user` (
`user_id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键',
`username` varchar(20) DEFAULT NULL COMMENT '用户名',
`balance` int(10) unsigned DEFAULT NULL COMMENT '余额(无符号)',
PRIMARY KEY (`user_id`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;

注意:该表的余额(balance)字段已设置为不能是负数(unsigned)

insert into `t_user`(`user_id`,`username`,`balance`) values (1,'admin',50);

image

14.3、不考虑事务的实现

14.3.1、创建持久层接口BookDao及其实现类

image

package org.rain.spring.dao;

/**
 * @author liaojy
 * @date 2023/8/2
首页 上一页 1 2 3 4 5 下一页 尾页 1/5/5
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇Java - ThreadPoolExecutor线程池.. 下一篇集群部署专题之二:超高性能RPC框..

最新文章

热门文章

Hot 文章

Python

C 语言

C++基础

大数据基础

linux编程基础

C/C++面试题目