日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

java中解决脏读_JAVA数据脏读

發(fā)布時(shí)間:2023/12/20 编程问答 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java中解决脏读_JAVA数据脏读 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

2014-03-21 回答

讀“臟”數(shù)據(jù)是指事務(wù)t1修改某一數(shù)據(jù),并將其寫(xiě)回磁盤(pán),事務(wù)t2讀取同一數(shù)據(jù)后,t1由于某種原因被除撤消,而此時(shí)t1把已修改過(guò)的數(shù)據(jù)又恢復(fù)原值,t2讀到的數(shù)據(jù)與數(shù)據(jù)庫(kù)的數(shù)據(jù)不一致,則t2讀到的數(shù)據(jù)就為“臟”數(shù)據(jù),即不正確的數(shù)據(jù)。

臟數(shù)據(jù)在比較復(fù)雜的交互式系統(tǒng)中,非常常見(jiàn)。

1、用java處理數(shù)據(jù)庫(kù)事務(wù)的準(zhǔn)備

要有一個(gè)能夠訪問(wèn)數(shù)據(jù)庫(kù)的應(yīng)用。下面的示例都基于oracle進(jìn)行。

create table ffm_account(

id int primary key ,

name varchar(32),

money int

);

測(cè)試數(shù)據(jù):

insert into ffm_account(id,name,money)values(1,'a',1000);

insert into ffm_account(id,name,money)values(2,'b',1000);

2、jdbc中使用事務(wù)

當(dāng)jdbc程序向數(shù)據(jù)庫(kù)獲得一個(gè)connection對(duì)象時(shí),默認(rèn)情況下這個(gè)connection對(duì)象會(huì)自動(dòng)向數(shù)據(jù)庫(kù)提交在它上面發(fā)送的sql語(yǔ)句。若想關(guān)閉這種默認(rèn)提交方式,讓多條sql在一個(gè)事務(wù)中執(zhí)行,可使用下列的jdbc控制事務(wù)語(yǔ)句

connection.setautocommit(false);//開(kāi)啟事務(wù)(start transaction)

connection.rollback();//回滾事務(wù)(rollback)

connection.commit();//提交事務(wù)(commit)

3、jdbc使用事務(wù)范例之臟數(shù)據(jù) 以及讀取臟數(shù)據(jù)的源代碼

在jdbc代碼中演示銀行轉(zhuǎn)帳案例,有兩個(gè)銀行賬戶,a和b,各自有1000塊錢; a往c賬戶轉(zhuǎn)賬100塊,然后去讀取a賬戶的錢,讀到了a賬戶只有900塊,但是c賬戶是不存在的,那么這筆錢應(yīng)該是轉(zhuǎn)賬失敗。

java源代碼:

package com.transaction;

import java.sql.connection;

import java.sql.preparedstatement;

import java.sql.resultset;

import com.db.easyc3p0;

/**

*有兩個(gè)銀行賬戶,a和b,各自有1000塊錢;

*a往c賬戶轉(zhuǎn)賬100塊,然后去讀取a賬戶的錢,讀到了a賬戶只有900塊,

*但是c賬戶是不存在的,那么這筆錢應(yīng)該是轉(zhuǎn)賬失敗。

*

*@author 范芳銘

*/

public class easydirtydata {

publicstatic void main(string[] args){

connectionconn = null;

preparedstatementstmt = null;

resultsetrs = null;

try{

conn =easyc3p0.getconnection();

//通知數(shù)據(jù)庫(kù)開(kāi)啟事務(wù)(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("轉(zhuǎn)賬執(zhí)行前,系統(tǒng)中全部金額為:" +rs.getint("money"));

}

stmt = conn.preparestatement(sqla_money);

rs = stmt.executequery();

if (rs.next()){

system.out.println("轉(zhuǎn)賬執(zhí)行前,a的金額為:"+ rs.getint("money"));

}

//簡(jiǎn)單模擬a往c賬戶轉(zhuǎn)賬:

string sqla = "update ffm_account set money=money-100 wherename='a'";

stmt = conn.preparestatement(sqla);

stmt.executeupdate();

//系統(tǒng)中沒(méi)有c賬戶

string sqlc = "update ffm_account set money=money+100 wherename='c'";

stmt = conn.preparestatement(sqlc);

stmt.executeupdate();

conn.commit();

//簡(jiǎn)單模擬a往c賬戶 結(jié)束

//轉(zhuǎn)賬結(jié)束后,看賬戶情況

stmt = conn.preparestatement(sqlallmoney);

rs = stmt.executequery();

if (rs.next()){

system.out.println("轉(zhuǎn)賬執(zhí)行后,系統(tǒng)中全部金額為:" +rs.getint("money"));

}

stmt = conn.preparestatement(sqla_money);

rs = stmt.executequery();

if (rs.next()){

system.out.println("轉(zhuǎn)賬執(zhí)行后,a的金額為:"+ rs.getint("money"));

}

}catch (exception e) {

e.printstacktrace();

}finally{

easyc3p0.close(conn, stmt, rs);

}

}

}

4、運(yùn)行結(jié)果

轉(zhuǎn)賬執(zhí)行前,系統(tǒng)中全部金額為:2000

轉(zhuǎn)賬執(zhí)行前,a的金額為:1000

轉(zhuǎn)賬執(zhí)行后,系統(tǒng)中全部金額為:1900

轉(zhuǎn)賬執(zhí)行后,a的金額為:900

總結(jié)

以上是生活随笔為你收集整理的java中解决脏读_JAVA数据脏读的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。