好记性不如烂笔头24-JAVA处理数据库事务(2) - 脏数据

读“脏”数据是指事务T1修改某一数据,并将其写回磁盘,事务T2读取同一数据后,T1由于某种原因被除撤消,而此时T1把已修改过的数据又恢复原值,T2读到的数据与数据库的数据不一致,则T2读到的数据就为“脏”数据,即不正确的数据。

脏数据在比较复杂的交互式系统中,非常常见。

1、用JAVA处理数据库事务的准备

要有一个能够访问数据库的应用。下面的示例都基于ORACLE进行。

create table ffm_account(

id int primary key ,

name varchar(32),

money int

);

测试数据:

insert into ffm_account(id,name,money)values(1,‘A‘,1000);

insert into ffm_account(id,name,money)values(2,‘B‘,1000);

2、JDBC中使用事务

当Jdbc程序向数据库获得一个Connection对象时,默认情况下这个Connection对象会自动向数据库提交在它上面发送的SQL语句。若想关闭这种默认提交方式,让多条SQL在一个事务中执行,可使用下列的JDBC控制事务语句

Connection.setAutoCommit(false);//开启事务(start transaction)

Connection.rollback();//回滚事务(rollback)

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

3、JDBC使用事务范例之脏数据 以及读取脏数据的源代码

在JDBC代码中演示银行转帐案例,有两个银行账户,A和B,各自有1000块钱; A往C账户转账100块,然后去读取A账户的钱,读到了A账户只有900块,但是C账户是不存在的,那么这笔钱应该是转账失败。

JAVA源代码:

package com.transaction;

import java.sql.Connection;

import java.sql.PreparedStatement;

import java.sql.ResultSet;

import com.db.EasyC3p0;

/**

*有两个银行账户,A和B,各自有1000块钱;

*A往C账户转账100块,然后去读取A账户的钱,读到了A账户只有900块,

*但是C账户是不存在的,那么这笔钱应该是转账失败。

*

*@author 范芳铭

*/

public class EasyDirtyData {

publicstatic void main(String[] args){

Connectionconn = null;

PreparedStatementstmt = null;

ResultSetrs = null;

try{

conn =EasyC3p0.getConnection();

//通知数据库开启事务(start transaction)

conn.setAutoCommit(false);

String sqlAllMoney = " select sum(money) as money from ffm_account";

String sqlA_money = " select money from ffm_account " ;

stmt = conn.prepareStatement(sqlAllMoney);

rs = stmt.executeQuery();

if (rs.next()){

System.out.println("转账执行前,系统中全部金额为:" +rs.getInt("money"));

}

stmt = conn.prepareStatement(sqlA_money);

rs = stmt.executeQuery();

if (rs.next()){

System.out.println("转账执行前,A的金额为:"+ rs.getInt("money"));

}

//简单模拟A往C账户转账:

String sqlA = "update ffm_account set money=money-100 wherename=‘A‘";

stmt = conn.prepareStatement(sqlA);

stmt.executeUpdate();

//系统中没有C账户

String sqlc = "update ffm_account set money=money+100 wherename=‘C‘";

stmt = conn.prepareStatement(sqlc);

stmt.executeUpdate();

conn.commit();

//简单模拟A往C账户 结束

//转账结束后,看账户情况

stmt = conn.prepareStatement(sqlAllMoney);

rs = stmt.executeQuery();

if (rs.next()){

System.out.println("转账执行后,系统中全部金额为:" +rs.getInt("money"));

}

stmt = conn.prepareStatement(sqlA_money);

rs = stmt.executeQuery();

if (rs.next()){

System.out.println("转账执行后,A的金额为:"+ rs.getInt("money"));

}

}catch (Exception e) {

e.printStackTrace();

}finally{

EasyC3p0.close(conn, stmt, rs);

}

}

}

4、运行结果

转账执行前,系统中全部金额为:2000

转账执行前,A的金额为:1000

转账执行后,系统中全部金额为:1900

转账执行后,A的金额为:900

系统中的钱那里去了,A:我的钱呢,还我钱!!!!!!!!!

时间: 2024-09-30 06:44:19

好记性不如烂笔头24-JAVA处理数据库事务(2) - 脏数据的相关文章

【好记性不如烂笔头】创建一颗用于快速查找数据的多叉树

假定现有大量人员需要管理,给每个人分配一个n位数的id,现要求快速查找,于是我们建一颗10叉树来管理这批人的信息,这样查找结果为真时查询次数为n,时间复杂度为常数,可谓是最优解了 代码如下: 1 using System; 2 using System.Collections.Generic; 3 using System.Diagnostics; 4 using System.Linq; 5 using System.Text; 6 using System.Threading.Tasks;

好记性不如烂笔头25-JAVA处理数据库事务(3) - 事务回滚点

在具体的工作中,有的事情需要被保持,不需要回滚,有的工作需要回滚,而这些逻辑,可以通过手动设置事务的回滚点. 1.用JAVA处理数据库事务的事务回滚点的准备 要有一个能够访问数据库的应用.下面的示例都基于ORACLE进行. create table ffm_account( id int primary key , name varchar(32), money int ); 测试数据: insert into ffm_account(id,name,money)values(1,'A',100

好记性不如烂笔头89-spring3学习(10)-spring3常用schema(持续整理)

Spring3有很多的schema,这些schema对应很多不同的功能.使用这些常用的schema,能让我们避免重复发明轮子,提高我们的开发效率. 我以为这是一个很常见的信息,到网上随便整理下就能完成,可能用的关键词不对,怎么找也没有找到相对比较全面的. 正所谓,好记性不如烂笔头,自己动手把自己能收集到的整理下来,以后需要找资料也能方便点. spring-beans-3.0.xsd 用途:spring3最主要的schema,用于配置bean 命名空间: http://www.springfram

好记性不如烂笔头48-java拦截器-JDK自带动态代理和CGLIB效率比较(3)

Java中自带的动态代理的类必须要实现一个接口,而且据说使用反射的效率也并不是很高.于是CGLIB就诞生了. 使用CGLib实现动态代理,完全不受代理类必须实现接口的限制,而且CGLib底层采用ASM字节码生成框架,使用字节码技术生成代理类,理论上比使用Java反射效率要高. 那么我们测试下,这个运行的效率如何. 1. 测试的准备情况 准备1:好记性不如烂笔头46-java拦截器-彻底理解动态代理的概念(1) http://blog.csdn.net/ffm83/article/details/

从“好记性不如烂笔头”“记问之学不足为人师”到“一事不知是我之耻”

“好记性不如烂笔头”错在一笔记容易丢失,二考验随时发生而笔记常不随身.因此记到大脑里最可靠. “记问之学不足为人师”错在低估记忆力的作用而盲目推崇推理逻辑,这像不打地基盖楼,要不不牢靠要不会垮. “一事不知是我之耻”这是一种认真积极的态度,这样才能应付随时出现的挑战. 2017年3月12日00:34:22

Python学习中的随笔,好记性不如烂笔头

本文 为博主看了 vamei 的blog 写下的随笔 . 致敬Vamei 1.type()   可以显示参数的类型 如 : a=12   type(a) 为 int 2.python的基本类型 为 int float bool string   如 int :  i=1   ,   float :  f=12.5  ,  bool : b= True  or  Flase , string :  s='Hello , word !' 使用前无需声明类型  即 动态类型 3.1序列有 tuple

好记性不如烂笔头

今天再次深刻领悟这个技能.tm竟然忘记博客园的用户名了.... 好记性不如烂笔头,布布扣,bubuko.com

开篇记(好记性不如烂笔头)

入园两年零三个月,我居然没有一点东西记载下来实在是不应该. 爷爷曾经告诉过我,好记性不如烂笔头.他告诉了我最鲜明的例子.爷爷的脑子一直很好用,记性也是比常人好上一些,当然这也直接导致了爷爷的性格很是高傲.爷爷年轻的时候喜欢舞文弄墨什么的,所以呢每逢人家红白喜事的时候都会去人家及里面瞅上一眼,看看人家送上的喜联或者挽联.有此爱好的还有我的一个另一个宋爷爷,他们经常约好一起的.爷爷老是自信于强悍的记忆能力,每次都是记在脑子中,而宋爷爷却每次都将那些很好的对联记载一个小本子上面.如今爷爷年纪越来越大,

博客开通啦,好记性不如烂笔头

好记性不如烂笔头,勤能补拙.2016年,我即将步入工作,结束十多年的学生生活.如果说,人生每一个阶段都是一个新的开始,那么,今年又是我新生的一年. 新年新希望, 第一:希望自己能够工作顺利,在自己的岗位上做一个称职又出色的员工 第二:希望自己能够每天都开开心心的 第三:努力变美,努力减肥.多读书,多看报,少吃零食多运动- 第四:努力学习.学习才能使自己更上一层楼,才能让自己实现自己的愿望,学无止境,自制,坚持,总结,记录. 第五:希望家人和朋友们都开开心心的,心想事成万事如意. 第六:希望,我和