《Spring入门经典》:使用Spring进行JDBC数据库访问、事务管理
mhr18 2024-09-21 19:05 25 浏览 0 评论
第四章:使用Spring进行JDBC数据访问
重点:使用普通JDBC访问所带来的问题
Spring的JDBC支持的优势
配置和使用Spring的JDBC支持
正确处理和转换SQLException和SQL错误代码
4.1使用普通JDBC访问,如下的数据库访问模板代码会散落在数据访问层的各个角落,长期维护将会变成一场噩梦。
Connection conn = null;try { Class.forName("oracle.jdbc.driver.OracleDriver"); String url="jdbc:oracle:thin:@192.168.5.108:1530:billdb"; String username="oracle"; String password=" oracle "; conn = DriverManager.getConnection(url, username, password); conn.setAutoCommit(false); //将自动提交设置为false conn.begin(); //执行CRUD操作 //业务处理 conn.commit(); //当CRUD操作成功后手动提交 }catch (Exception e) { conn.rollback();}finally { conn.close(); }
4.2.1管理JDBC连接,两种方式,一种是DriverManager,另一种是DataSource。
DriverManagerDataSource是DataSource接口的简单实现,不具备连接池功能,每次使用都会尝试打开新的物理JDBC连接,非常耗性能。
SingleConnectionDataSource是DataSource接口另一种实现,该类重复使用相同的连接。
BasicDataSource是带有连接池功能的DataSource实例,对于企业级Java生产环境推荐使用。
4.2.2配置和使用Spring的JDBC支持
Spring的JDBC支持核心类是JdbcTemplate,该类是线程安全的,主要依赖项是一个DataSource对象。
public JdbcTemplate(DataSource dataSource) {
setDataSource(dataSource);
afterPropertiesSet();
}
public JdbcTemplate(DataSource dataSource, boolean lazyInit) {
setDataSource(dataSource);
setLazyInit(lazyInit);
afterPropertiesSet();
}
4.3使用Spring执行数据库访问
JdbcTemplate实现了Template Method模式,该模式尝试将一个算法的主要步骤进行封装,从而能够让开发人员通过方法参数更改算法的不同部分。下面列几个常用的数据库访问方法:
public class JdbcTemplate {
void execute(String sql) throws DataAccessException;
<T> List<T> query(String sql, RowMapper<T> rowMapper) throws DataAccessException;
<T> T queryForObject(String sql, RowMapper<T> rowMapper) throws DataAccessException;
Map<String, Object> queryForMap(String sql) throws DataAccessException;
List<Map<String, Object>> queryForList(String sql) throws DataAccessException;
SqlRowSet queryForRowSet(String sql) throws DataAccessException;
int update(String sql) throws DataAccessException;
int[] batchUpdate(String... sql) throws DataAccessException;
……
……
}
4.5.2SQLException的自动处理和转换
第五章:通过Spring使用JPA进行数据库访问,暂且忽略待研究。
第六章:使用Spring管理事务
重点:理解事务管理的工作原理
Spring事务抽象的优点
使用Spring执行声明式和编程式事务管理
细节参考spring事务管理与配置
Spring事务传播性
connection.setAutoCommit(false);用来定义事务边界的起点;
connection. commit();用来定义事务成功终止;
connection. rollback();用来定义事务失败终止,告诉JDBC抛弃所做的任何更改;
6.4使用Spring进行编程式事务管理
(1)使用TransactionTemplate,Spring推荐方法;
(2)直接使用PlatformTransactionManager,这是一种低级的方法。
@Override
public void transferA(final String out, final String in, final Double money)
throws Exception {
transactionTemplate.execute(new TransactionCallbackWithoutResult() {
protected void doInTransactionWithoutResult(TransactionStatus status) {
//执行CRUD操作 //业务处理
}
});
}
注意:在类和方法上都不使用@Transactional注解
TransactionTemplate是基于Template Method模式。当一个算法的主要流程被预先定义且固定时,该模式是非常有用的。我们只需要通过回调将更改的部分添加到算法中,就可以在正确的时间在算法逻辑流程中执行这些部分。
try
{
begin transaction
execute transactional code block//TODO:回调
commit transaction
} catch (Exception e)
{
// TODO: handle exception
rollback transaction
} finally {
do resource clean up
}
TransactionTemplate,不管是受检查的异常还是非检查异常,都会执行回滚操作。
6.5在事务之前或之后执行自定义逻辑
允许开发人员注册一个自定义业务逻辑,可以在当前事务划分之前或之后执行该逻辑。有两种实现方法:一种是Spring Aop,另一种是注册一个在当前事务结束时执行的回调实例TransactionSynchronization。
6.5.1通知事务性操作,可以通过实现MethodInterceptor接口来拦截方法调用
public interface MethodInterceptor extends Interceptor {
Object invoke(MethodInvocation invocation) throws Throwable;
}
public class Profiler implements MethodInterceptor
{
@Override
public Object invoke(MethodInvocation invocation) throws Throwable {
// TODO 调用之前做一些额外操作
try
{
return invocation.proceed();
} finally
{
// TODO: 调用之后做一些额外操作
}
}
}
6.5.2使用TransactionSynchronization,在执行事务之后执行自定义业务逻辑的回调接口
public interface TransactionSynchronization extends Flushable {
int STATUS_COMMITTED = 0;
int STATUS_ROLLED_BACK = 1;
int STATUS_UNKNOWN = 2;
void suspend();
void resume();
@Override
void flush();
void beforeCommit(boolean readOnly);
void beforeCompletion();
void afterCommit();
void afterCompletion(int status);
}
相关推荐
- Springboot数据访问(整合动态数据源)
-
Springboot整合动态数据源dynamic-datasource-spring-boot-starter基本概念这个依赖是MyBatis-Plus团队开发的动态数据源组件,它是一个基于Spri...
- 《有手就会写sql》-第1章 数据库(sql实时更新同表里某个字段的数据)
-
为啥要用数据库存放数据的方式,有很多种,常用的比如:excel,数据库等。有了excel,为啥还要用数据库呢?原因有很多。其中之一:excel存储的数据有限的,最多能存个几千万条。但一个银行的交易数据...
- DBdoctor:一款企业级数据库性能诊断工具
-
DBdoctor是一个全面覆盖开发、测试、运维等各个环节SQL审核以及数据库性能诊断与优化的监控平台。针对数据库性能诊断门槛高、耗时长的问题,DBdoctor提供了快速易用的解决方案,深入到数...
- 面试必问:MySQL死锁 是什么,如何解决?(史上最全)
-
MySQL死锁接触少,但面试又经常被问到怎么办?最近有小伙伴在面试的时候,被问了MySQL死锁,如何解决?虽然也回答出来了,但是不够全面体系化,所以,小北给大家做一下系统化、体系化的梳理,帮助大家在面...
- JAVA入门教程-第1章 概述(java入门篇)
-
大道至简-JAVA入门教程在本教程中,你将学习Java语言的基础知识。Java基础内容涵盖:Java基础概念、Java词法结构、Java数组、Java流程控制、Java字符串、Java...
- 突发消息!微软停止俄罗斯业务(微软停止服务怎么办)
-
越来越多的IT公司加入封杀俄罗斯的阵营中。数字化转型网先后关注的有(点击下方蓝字可打开文章):SAP停止俄罗斯所有业务乌克兰呼吁SAP、Oracle封杀俄罗斯,Oracle已停止在俄所有业务埃森哲停止...
- 分布式数据库设计——存储引擎原理(全)
-
摘要数据库的一个首要目标是可靠并高效地管理数据,以供人们使用。进而不同的应用可以使用相同的数据库来共享它们的数据。数据库的出现使人们放弃了为每个独立的应用开发数据存储的想法,同时,随着数据库广泛的使用...
- Java运行环境配置(java运行环境配置成功截图)
-
若要在计算机上运行Java程序,需要配置Java运行环境(JRE)或Java开发工具包(JDK)。以下是在Windows操作系统上配置Java运行环境的步骤:下载Java安装程序:前往Oracle官方...
- 分布式任务调度Celery(分布式任务调度平台)
-
本文介绍了分布式任务调度系统Celery,包括安装,开发使用,并且配合supervisor,flower等工具进行系统化部署和使用。(一)安装和代码开发使用示例一,简介Celery是一个分布式任务调度...
- Android SDK 安装与配置(android sdk安装在哪里)
-
AndroidSDK安装与配置全流程指南一、前期准备与环境要求1.系统兼容性验证o操作系统:支持Windows10/11(64位)、macOS10.14+、Ubuntu16.04+等主流...
- 高性能Linux服务器构建实战:运维监控、性能调优与集群应用
-
百万级字迹详解实战案例,篇幅因素故只展现pdf目录,完整解析获取方式在篇尾了!目录读者对象Web应用篇(1至第3章)数据备份恢复篇(4至第6章)网络存储应用篇(7和第8章)运维监控与性能优化篇(9和第...
- Vmware虚拟机迁移数据库时踩过的坑
-
从Vmware迁移数据库虚拟机到其他平台,起来后认不到asm盘,不禁傻眼了。很多时候为了保证虚拟机系统的完整可启动,在做任何变更前,领导都会要求克隆一份镜像保存,或者直接在镜像上操作。这是传统的备份理...
- Java 中 java.util.Date 与 java.sql.Date 有什么区别?
-
Java里的java.util.Date和java.sql.Date绝对是那种看起来不起眼但能搞得你Debug到半夜的“坑王”。我们先从表面上看,java.sql.Date是继承自j...
- 主流数据库的不同点在哪?MySQL和SQL Server的区别介绍
-
在本教程中,树懒君介绍了两种最普遍应用的RDBMS—MySQL和MicrosoftSQLServer。通过介绍MySQL和SQLServer的几个关键区别,希望大家能在这两者之间做出最适合自己的...
- Java安全-Java Vuls(Fastjson、Weblogic漏洞复现)
-
复现几个Java的漏洞,文章会分多篇这是第一篇,文章会分组件和中间件两个角度进行漏洞复现复现使用环境VulhubVulFocus组件Fastjson1.2.24反序列化RCEFastJson...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- oracle位图索引 (74)
- oracle批量插入数据 (65)
- oracle事务隔离级别 (59)
- oracle 空为0 (51)
- oracle主从同步 (56)
- oracle 乐观锁 (51)
- redis 命令 (78)
- php redis (88)
- redis 存储 (66)
- redis 锁 (69)
- 启动 redis (66)
- redis 时间 (56)
- redis 删除 (67)
- redis内存 (57)
- redis并发 (52)
- redis 主从 (69)
- redis 订阅 (51)
- redis 登录 (54)
- redis 面试 (58)
- 阿里 redis (59)
- redis 搭建 (53)
- redis的缓存 (55)
- lua redis (58)
- redis 连接池 (61)
- redis 限流 (51)