事务之使用JDBC进行事务的操作
本篇讲述数据库中非常重要的事务概念和如何使用MySQL命令行窗口来进行数据库的事务操作。下一篇会讲述如何使用JDBC进行数据库的事务操作。
事务是指数据库中的一组逻辑操作,这个操作的特点就是在该组逻辑中,所有的操作要么全部成功,要么全部失败。在各个数据具有特别紧密的联系时,最好是使用数据库的事务来完成逻辑处理。
例如路人甲A给路人甲B转账1000元,对应于如下两条SQL命令:
update from account set money=money-1000 where name=’A’;
update from account set money=money+1000 where name=’B’;
在上面两条SQL语句中,任意一条SQL执行过程中出现了错误,那么就有可能造成A与B两人最后总金额的错误。但如果是使用事务来处理,即使上面的转账过程出现了错误,那么之前执行的数据库操作即使成功也会一并回滚,形成所有的SQL操作全部失败,保证所有人的金额不变。
MySQL数据库默认事务是自动提交的,也就是发一条SQL数据库就执行一条。如果想将多条SQL放置在一个事务中执行,就必须使用如下语句:
start transaction
sql1
sql2
…
commit
当开启事务后(start transaction),无论数据库是否对其中的多条SQL语句是否执行成功,只要没有提交事务(commit),都会将之前执行的SQL进行回滚。使数据回到开启事务之前的值。
在MySQL中,与事务相关的有开启事务(START TRANSACTION),提交事务(COMMIT),回滚事务(ROLLBACK)等等,下面将依次使用到。
接下来将会在先使用数据库命令行窗口来进行事务操作的案例。
首先定义表account和客户以及金额两个列数据项:

create database jdbcdemo;
use jdbcdemo;
create table account(
id int primary key auto_increment,
name varchar(40),
money double
);
insert into account(name,money) values('a',1000);
insert into account(name,money) values('b',1000);

准备完成:

⑴ 开启事务,先来模拟转账“失败”的情况:
输入以下SQL语句,来模拟A向B转账1000元:
start transaction;
update account set money=money-1000 where name=’a’;
假设数据库执行到此发生了错误,我们将MySQL的命令行窗口关闭来代替这样的“错误”:

这时如果我们再重新打开MySQL命令行窗口,重新查看用户的金额,发现由于我们开启事务后,并未提交(commit),因此导致事务回滚,之前执行的SQL语句全部不算成功,因此即使数据库可能发生了错误,用户金额还是能由事务保证不出意外:

⑵ 开启事务,并提交事务模拟成功的转账:
还是上面的例子,这次我们在开启事务,输入SQL命令,最后提交事务(Commit),来确保这个事务内所有的SQL命令都能被执行成功,输入以下SQL语句:
start transaction;
update account set money=money-1000 where name=’a’;
update account set money=money+1000 where name=’b’;
commit;
即为下面的样子:

这时候即使我将MySQL命令行窗口关闭模拟提交事务后再出错的情况,那么重新查询用户金额还是能看出转账已经在出错前确保完成了:

通过上面两个例子可以看出,如果我们想将多条SQL作为整体执行,只要有一个条SQL执行失败或者数据库突然出错就回滚到最开始执行之前的状态,使用事务是最好的选择。
⑶ 回滚事务,将之前所有已执行的SQL全部视为无效:
最后来看看事务回滚(ROLLBACK)。如果我们在事务处理的过程中,提交事务(Commit)之前,如果想回滚之前的操作,可以使用ROLLBACK这条SQL命令。
注:使用ROLLBACK命令将回滚之前到开启事务的所有SQL语句。
还是以上面的A与B两个用户的金额为例,现在两者的金额都为1000:

现在我们开启事务,执行几条SQL命令,然后再将这些已经执行的SQL命令回滚:

使用ROLLBACK命令会回滚该事务内所有之前执行的SQL命令,不会只回滚前面一条SQL命令,因此即使我们对A和B的金额操作了多次,最终还是回到事务开启前的金额数:

以上介绍完在数据库命令行窗口如何进行与事务相关的操作,主要就是开启事务,提交事务和回滚事务这三种,当然作为Java程序员,我们应该还是使用JDBC来操作数据库的事务处理,这部分内容将会在下一篇博客中介绍到。
事务之使用JDBC进行事务的操作的更多相关文章
- 事务之使用JDBC进行事务的操作2
本篇将讲诉如何使用JDBC进行数据库有关事务的操作.在上一篇博客中已经介绍了事务的概念,和在MySQL命令行窗口进行开启事务,提交事务以及回滚事务的操作. 似乎事务和批处理都可以一次同时执行多条SQL ...
- spring not_support 该方法被事务方法调用时 不会加入spring事务 只是执行jdbc普通的事务
- day18-事务与连接池 3.jdbc中事务操作介绍
那么我们都是通过程序操作数据库.所以要了解jdbc下怎样对事务操作.jdbc如何操作事务? 自动事务false那就不开了呗相当于开启事务. package cn.itcast.transaction; ...
- Spring总结——AOP、JDBC和事务的总结
1.上一次总结了 Spring 的核心三大组件(Core,Beans,Context),今天总结的 AOP.JDBC和事务都可以看成是核心三大组件的应用. 其中 Spring 的事务管理又以 AOP ...
- jdbc、事务(Transaction)、批处理 回顾
论文写的头疼,回顾一下jdbc,换换脑子 传统的写法: 1.加载驱动类 class.forname("jdbc类的包结构"); 2.获得连接 Connection conn=Dri ...
- 【JDBC】事务的使用
转载请注明原文地址:http://www.cnblogs.com/ygj0930/p/5868750.html 关于事务的理论知识.ACID特性等等,网上太多了,在此不一一重复.本文主要着重 事务 ...
- MySql事务及JDBC对事务的使用
一 .事务的几个重要特性 1. 原子性 事务内的每个内容不可分割,是一个统一的整体.或同时进行或同时消亡. 2.一致性 事务执行前和事务执行后,状态都是统一的.如A转B 100元,A和B数据总额度没有 ...
- JDBC 之 事务
1.概念:事务指逻辑上的一组操作,组成这组操作的各个单元,要么全部成功,要么全部不成功. 2.数据库开启事务的命令dtl: Start transaction开启事务 Rollback回滚事务(撤销) ...
- JDBC之事务隔离级别以及ACID特性
JDBC之事务隔离级别以及ACID特性 事务隔离级别: 1.更新遗失(Lost update) 两个事务都同时更新一行数据,但是第二个事务却中途失败退出,导致对数据的两个修改都失效了.这是因为系统没有 ...
随机推荐
- Java泛型学习
1.泛型的概念 泛型即"参数化类型",就比如我们定义方法的时候,定义一个变量,称为形参,变量值根据传进去的实参的值不同而改变.而泛型的出现,就是为了解决类型也能根据传进去的类型改变 ...
- 化繁为简(三)—探索Mapreduce简要原理与实践
目录-探索mapreduce 1.Mapreduce的模型简介与特性?Yarn的作用? 2.mapreduce的工作原理是怎样的? 3.配置Yarn与Mapreduce.演示Mapreduce例子程序 ...
- 最新Hadoop Shell完全讲解
本文为原创博客,转载请注明出处:http://www.cnblogs.com/MrFee/p/4683953.html 1.appendToFile 功能:将一个或多个源文件系统的内容追加至 ...
- 一键帮你复制多个文件到多个机器——PowerShell小脚本(内附PS远程执行命令问题解析)
作为一个后台程序猿,经常需要把一堆程序集(DLL)或者应用程序(EXE)复制到多个服务器上,实现程序的代码逻辑更新,用以测试新的功能或改动逻辑.这里给大家介绍一个自己实现的PowerShell脚本,方 ...
- Xamarin开发笔记—百度在线语音合成
语音合成:也被称为文本转换技术(TTS),它是将计算机自己产生的.或外部输入的文字信息转变为可以听得懂的.流利的口语输出的技术. 技术选型:语音合成初步选择有两个,一是讯飞.二是百度. 因为使用的是X ...
- java原生实现屏幕设备遍历和屏幕采集(捕获)等功能
前言:本章中屏幕捕获使用原生java实现,屏幕图像显示采用javacv1.3的CanvasFrame 一.实现的功能 1.屏幕设备遍历 2.本地屏幕图像采集(也叫屏幕图像捕获) 3.播放本地图像(采用 ...
- 每天一个JS 小demo之留言板。主要知识点:DOM方法的理解和运用
<!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"& ...
- 东北育才 DAY2组合数取mod (comb)
组合数取模(comb) [问题描述] 计算C(m,n)mod 9901的值 [输入格式] 从文件comb.in中输入数据. 输入的第一行包含两个整数,m和n [输出格式] 输出到文件comb.out中 ...
- 【解决】安装compass失败(gem install compass)
原始日期:2016-01-25 16:26 这个问题比较常见. 很多人在安装ruby后再使用gem install compass命令安装compass,发现安装失败. [解决方法:] / ...
- 【知识整理】这可能是最好的RxJava 2.x 入门教程(三)
这可能是最好的RxJava 2.x入门教程系列专栏 文章链接: 这可能是最好的RxJava 2.x 入门教程(一) 这可能是最好的RxJava 2.x 入门教程(二) GitHub 代码同步更新:ht ...