Spring之事务(1)

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
可观测可视化 Grafana 版,10个用户账号 1个月
简介: 【1月更文挑战第16天】一、JdbcTemplate1、简介2、准备工作3、实现CURD①装配 JdbcTemplate②测试增删改功能③查询数据返回对象④查询数据返回list集合⑤查询返回单个的值二、声明式事务概念1、事务基本概念①什么是事务②事务的特性2、编程式事务3、声明式事务

文章目录

前言

一、JdbcTemplate

1、简介

2、准备工作

3、实现CURD

①装配 JdbcTemplate

②测试增删改功能

③查询数据返回对象

④查询数据返回list集合

⑤查询返回单个的值

二、声明式事务概念

1、事务基本概念

①什么是事务

②事务的特性

2、编程式事务

3、声明式事务

总结


前言

一、JdbcTemplate

1、简介

2、准备工作

3、实现CURD

①装配 JdbcTemplate

②测试增删改功能

③查询数据返回对象

④查询数据返回list集合

⑤查询返回单个的值

二、声明式事务概念

1、事务基本概念

①什么是事务

②事务的特性

2、编程式事务

3、声明式事务


一、JdbcTemplate

1、简介

Spring 框架对 JDBC 进行封装,使用 JdbcTemplate 方便实现对数据库操作

2、准备工作

①搭建子模块

搭建子模块:spring-jdbc-tx

②加入依赖

<dependencies><!--spring jdbc  Spring 持久化层支持jar包--><dependency><groupId>org.springframework</groupId><artifactId>spring-jdbc</artifactId><version>6.0.2</version></dependency><!-- MySQL驱动 --><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>8.0.30</version></dependency><!-- 数据源 --><dependency><groupId>com.alibaba</groupId><artifactId>druid</artifactId><version>1.2.15</version></dependency></dependencies>

③创建jdbc.properties

jdbc.user=root
jdbc.password=root
jdbc.url=jdbc:mysql://localhost:3306/spring?characterEncoding=utf8&useSSL=false
jdbc.driver=com.mysql.cj.jdbc.Driver

④配置Spring的配置文件

beans.xml

<?xmlversion="1.0" encoding="UTF-8"?><beansxmlns="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/beanshttp://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/contexthttp://www.springframework.org/schema/context/spring-context.xsd"><!-- 导入外部属性文件 --><context:property-placeholderlocation="classpath:jdbc.properties"/><!-- 配置数据源 --><beanid="druidDataSource"class="com.alibaba.druid.pool.DruidDataSource"><propertyname="url"value="${jdbc.url}"/><propertyname="driverClassName"value="${jdbc.driver}"/><propertyname="username"value="${jdbc.user}"/><propertyname="password"value="${jdbc.password}"/></bean><!-- 配置 JdbcTemplate --><beanid="jdbcTemplate"class="org.springframework.jdbc.core.JdbcTemplate"><!-- 装配数据源 --><propertyname="dataSource"ref="druidDataSource"/></bean></beans>

⑤准备数据库与测试表

CREATE DATABASE `spring`;use `spring`;CREATETABLE `t_emp` (  `id` int(11)NOTNULL AUTO_INCREMENT,  `name` varchar(20) DEFAULT NULL COMMENT '姓名',  `age` int(11) DEFAULT NULL COMMENT '年龄',  `sex` varchar(2) DEFAULT NULL COMMENT '性别',  PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

3、实现CURD

①装配 JdbcTemplate

创建测试类,整合JUnit,注入JdbcTemplate

packagecom.gedeshidai.spring6;
importorg.springframework.beans.factory.annotation.Autowired;
importorg.springframework.jdbc.core.JdbcTemplate;
importorg.springframework.test.context.junit.jupiter.SpringJUnitConfig;
@SpringJUnitConfig(locations="classpath:beans.xml")
publicclassJDBCTemplateTest {
@AutowiredprivateJdbcTemplatejdbcTemplate;
}

②测试增删改功能

@Test//测试增删改功能publicvoidtestUpdate(){
//添加功能Stringsql="insert into t_emp values(null,?,?,?)";
intresult=jdbcTemplate.update(sql, "张三", 23, "男");
//修改功能//String sql = "update t_emp set name=? where id=?";//int result = jdbcTemplate.update(sql, "张三atguigu", 1);//删除功能//String sql = "delete from t_emp where id=?";//int result = jdbcTemplate.update(sql, 1);}

③查询数据返回对象

publicclassEmp {
privateIntegerid;
privateStringname;
privateIntegerage;
privateStringsex;
//生成get和set方法//......@OverridepublicStringtoString() {
return"Emp{"+"id="+id+", name='"+name+'\''+", age="+age+", sex='"+sex+'\''+'}';
    }
}
//查询:返回对象@TestpublicvoidtestSelectObject() {
//写法一//        String sql = "select * from t_emp where id=?";//        Emp empResult = jdbcTemplate.queryForObject(sql,//                (rs, rowNum) -> {//                    Emp emp = new Emp();//                    emp.setId(rs.getInt("id"));//                    emp.setName(rs.getString("name"));//                    emp.setAge(rs.getInt("age"));//                    emp.setSex(rs.getString("sex"));//                    return emp;//                }, 1);//        System.out.println(empResult);//写法二Stringsql="select * from t_emp where id=?";
Empemp=jdbcTemplate.queryForObject(sql,
newBeanPropertyRowMapper<>(Emp.class),1);
System.out.println(emp);
}

④查询数据返回list集合

@Test//查询多条数据为一个list集合publicvoidtestSelectList(){
Stringsql="select * from t_emp";
List<Emp>list=jdbcTemplate.query(sql, newBeanPropertyRowMapper<>(Emp.class));
System.out.println(list);
}

⑤查询返回单个的值

@Test//查询单行单列的值publicvoidselectCount(){
Stringsql="select count(id) from t_emp";
Integercount=jdbcTemplate.queryForObject(sql, Integer.class);
System.out.println(count);
}

二、声明式事务概念

1、事务基本概念

①什么是事务

数据库事务( transaction)是访问并可能操作各种数据项的一个数据库操作序列,这些操作要么全部执行,要么全部不执行,是一个不可分割的工作单位。事务由事务开始与事务结束之间执行的全部数据库操作组成。

②事务的特性

A:原子性(Atomicity)

一个事务(transaction)中的所有操作,要么全部完成,要么全部不完成,不会结束在中间某个环节。事务在执行过程中发生错误,会被回滚(Rollback)到事务开始前的状态,就像这个事务从来没有执行过一样。

C:一致性(Consistency)

事务的一致性指的是在一个事务执行之前和执行之后数据库都必须处于一致性状态。

如果事务成功地完成,那么系统中所有变化将正确地应用,系统处于有效状态。

如果在事务中出现错误,那么系统中的所有变化将自动地回滚,系统返回到原始状态。

I:隔离性(Isolation)

指的是在并发环境中,当不同的事务同时操纵相同的数据时,每个事务都有各自的完整数据空间。由并发事务所做的修改必须与任何其他并发事务所做的修改隔离。事务查看数据更新时,数据所处的状态要么是另一事务修改它之前的状态,要么是另一事务修改它之后的状态,事务不会查看到中间状态的数据。

D:持久性(Durability)

指的是只要事务成功结束,它对数据库所做的更新就必须保存下来。即使发生系统崩溃,重新启动数据库系统后,数据库还能恢复到事务成功结束时的状态。

2、编程式事务

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

Connectionconn= ...;
try {
// 开启事务:关闭事务的自动提交conn.setAutoCommit(false);
// 核心操作// 提交事务conn.commit();
}catch(Exceptione){
// 回滚事务conn.rollBack();
}finally{
// 释放数据库连接conn.close();
}

编程式的实现方式存在缺陷:

  • 细节没有被屏蔽:具体操作过程中,所有细节都需要程序员自己来完成,比较繁琐。
  • 代码复用性不高:如果没有有效抽取出来,每次实现功能都需要自己编写代码,代码就没有得到复用。

3、声明式事务

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

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

  • 好处1:提高开发效率
  • 好处2:消除了冗余的代码
  • 好处3:框架会综合考虑相关领域中在实际开发环境下有可能遇到的各种问题,进行了健壮性、性能等各个方面的优化

所以,我们可以总结下面两个概念:

  • 编程式自己写代码实现功能
  • 声明式:通过配置框架实现功能

总结

以上就是Spring之事务(1)的相关知识点,希望对你有所帮助。

积跬步以至千里,积怠惰以至深渊。时代在这跟着你一起努力哦!

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
18天前
|
Java 数据库 开发者
|
2月前
|
监控 Java 数据处理
【Spring云原生】Spring Batch:海量数据高并发任务处理!数据处理纵享新丝滑!事务管理机制+并行处理+实例应用讲解
【Spring云原生】Spring Batch:海量数据高并发任务处理!数据处理纵享新丝滑!事务管理机制+并行处理+实例应用讲解
|
2月前
|
Java 数据库 Spring
Spring事务失效的场景详解
Spring事务失效的场景详解
37 0
|
2月前
|
Java 数据库 Spring
Spring事务的传播机制(行为、特性)
Spring事务的传播机制(行为、特性)
40 0
|
3月前
|
Java 关系型数据库 数据库连接
Spring源码解析--深入Spring事务原理
本文将带领大家领略Spring事务的风采,Spring事务是我们在日常开发中经常会遇到的,也是各种大小面试中的高频题,希望通过本文,能让大家对Spring事务有个深入的了解,无论开发还是面试,都不会让Spring事务成为拦路虎。
39 1
|
3天前
|
SQL Java 关系型数据库
Spring 事务
Spring 事务
6 1
|
5天前
|
Java 数据库连接 数据库
Spring事务简介,事务角色,事务属性
Spring事务简介,事务角色,事务属性
15 2
|
9天前
|
Java 数据库连接 数据库
16:事务-Java Spring
16:事务-Java Spring
26 5
|
11天前
|
消息中间件 Java 关系型数据库
Spring事务与分布式事务
这篇文档介绍了事务的概念和数据库事务的ACID特性:原子性、一致性、隔离性和持久性。在并发环境下,事务可能出现更新丢失、脏读和不可重复读等问题,这些问题通过设置事务隔离级别(如读未提交、读已提交、可重复读和序列化)来解决。Spring事务传播行为有七种模式,影响嵌套事务的执行方式。`@Transactional`注解用于管理事务,其属性包括传播行为、隔离级别、超时和只读等。最后提到了分布式事务,分为跨库和跨服务两种情况,跨服务的分布式事务通常通过最终一致性策略,如消息队列实现。
|
12天前
|
监控 Java 测试技术
Spring Boot与事务钩子函数:概念与实战
【4月更文挑战第29天】在复杂的业务逻辑中,事务管理是确保数据一致性和完整性的关键。Spring Boot提供了强大的事务管理机制,其中事务钩子函数(Transaction Hooks)允许开发者在事务的不同阶段插入自定义逻辑。本篇博客将详细探讨事务钩子函数的概念及其在Spring Boot中的应用。
35 1