欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

JDBC編程的事務(wù)處理

一、事務(wù)的基本概念

創(chuàng)新互聯(lián)建站主營(yíng)湘陰網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營(yíng)網(wǎng)站建設(shè)方案,手機(jī)APP定制開(kāi)發(fā),湘陰h5微信小程序開(kāi)發(fā)搭建,湘陰網(wǎng)站營(yíng)銷(xiāo)推廣歡迎湘陰等地區(qū)企業(yè)咨詢(xún)

    數(shù)據(jù)庫(kù)是一個(gè)多用戶(hù)使用的共享資源。當(dāng)多個(gè)用戶(hù)并發(fā)地存取數(shù)據(jù)的時(shí)候,在數(shù)據(jù)庫(kù)中就會(huì)產(chǎn)生多個(gè)用戶(hù)同時(shí)存取同一數(shù)據(jù)的情況。若對(duì)并發(fā)操作不加控制,就可能會(huì)產(chǎn)生讀取和存儲(chǔ)不正確的數(shù)據(jù),破壞數(shù)據(jù)的一致性。

    而事務(wù)是并發(fā)控制的基本單位。所謂事務(wù),即一個(gè)操作序列。這些操作要么都執(zhí)行,要么都不執(zhí)行,它是一個(gè)不可分割的工作單位。比如銀行轉(zhuǎn)賬工作:從一個(gè)賬戶(hù)扣款,并使用另一個(gè)賬戶(hù)收款,這兩個(gè)操作要么都執(zhí)行,要么都不執(zhí)行,因此應(yīng)該把它們看作是一個(gè)事務(wù)。

    事務(wù)是數(shù)據(jù)庫(kù)維護(hù)數(shù)據(jù)一致性的單位,在每個(gè)事務(wù)結(jié)束時(shí),都能保持?jǐn)?shù)據(jù)的一致性。

    對(duì)于編程人員來(lái)說(shuō),可以把數(shù)據(jù)庫(kù)事務(wù)看作是一組sql語(yǔ)句,這組sql語(yǔ)句是一個(gè)邏輯工作單元,它們是不可分割的,它們的執(zhí)行結(jié)果應(yīng)該作為一個(gè)整體永久修改一個(gè)數(shù)據(jù)庫(kù)的內(nèi)容或者作為一個(gè)整體取消對(duì)數(shù)據(jù)庫(kù)的修改。

    

二、事務(wù)的四個(gè)基本特征

    1.原子性

    原子性是指事務(wù)中包含的操作都被看作是一個(gè)邏輯單元,這個(gè)邏輯單元中的操作要么全部成功,要么全部失敗。這也意味著事務(wù)中的所有元素作為一個(gè)整體提交或回滾。事務(wù)的所有元素是不可分割的,是一個(gè)完整的操作。

    2.一致性

    一致性是指事務(wù)開(kāi)始之前和事務(wù)結(jié)束以后數(shù)據(jù)庫(kù)都處于一致性狀態(tài),數(shù)據(jù)庫(kù)的完整性約束沒(méi)有被破壞。

     3.隔離性

    隔離性是指對(duì)數(shù)據(jù)庫(kù)進(jìn)行修改的多個(gè)事務(wù)是彼此隔離的。這說(shuō)明事務(wù)必須是獨(dú)立的,不應(yīng)該以任何形式影響其他事務(wù)

    4.持久性

    持久性是指事務(wù)完成之后對(duì)于數(shù)據(jù)庫(kù)的影響是永久的,該修改真實(shí)地修改了數(shù)據(jù)庫(kù),即使數(shù)據(jù)庫(kù)出現(xiàn)故障也會(huì)一直保留。

三、與SQL相關(guān)的事務(wù)語(yǔ)句

    開(kāi)始事務(wù):BEGIN TRANSACTION

    提交事務(wù):COMMIT TRANSATION

    回滾事務(wù):ROLLBACK TRANSATION    

package com.eduask.jdbc;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;

/*將要測(cè)試的邏輯
  保存一個(gè)用戶(hù)Tom的基本信息和Tom的地址信息
  分別通過(guò)兩個(gè)java方法插入到用戶(hù)表和地址表中 
  在插入地址表的時(shí)候人為造成一個(gè)異常
  觀察結(jié)果
 */
public class TransactionTest {
	
	//創(chuàng)建一個(gè)getConnection()用來(lái)獲取數(shù)據(jù)庫(kù)的連接
	public static Connection getConnection(){
		Connection conn = null;
		
		try {
			Class.forName("com.MySQL.jdbc.Driver");
			conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/testdemo","root","root");
		} catch (Exception e) {
			e.printStackTrace();
		}
		
		return conn;
	}
	
	public static void insertUserData(Connection conn) throws SQLException{
			String sql = "insert into tbl_user(id,name,password,email) "
					+ "values(10,'Tom','123456','tom@gmail.com')";
			Statement st = conn.createStatement();
			int count = st.executeUpdate(sql);
			System.out.println("向用戶(hù)插入了 "+ count + " 條記錄");
	}
	
	public static void insertAddressData(Connection conn) throws SQLException{
			String sql = "insert into tbl_address(id,city,country,user_id) "
					+ "values(1,'ShangHai','China','10')";
			Statement st = conn.createStatement();
			int count = st.executeUpdate(sql);
			System.out.println("向地址表中插入了 "+ count + " 條記錄");
	}
	
	public static void main(String[] args) {
		Connection conn = null;
		try {
			conn = getConnection();
			conn.setAutoCommit(false);
			
			insertUserData(conn);
			insertAddressData(conn);
			
			conn.commit();
		} catch (SQLException e) {
			System.out.println("=========捕獲到SQL異常=========");
			
			e.printStackTrace();
			try {
				conn.rollback();//回滾事務(wù),保證數(shù)據(jù)庫(kù)數(shù)據(jù)的一致性
				System.out.println("=========事務(wù)回滾成功=========");
			} catch (Exception e2) {
				e2.printStackTrace();
			}
		}finally{
			try {
				if (conn != null) {
					conn.close();
				}
			} catch (Exception e3) {
				e3.printStackTrace();
			}
		}
	}
	
	
}

本文題目:JDBC編程的事務(wù)處理
本文來(lái)源:http://chinadenli.net/article32/gghpsc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供App設(shè)計(jì)營(yíng)銷(xiāo)型網(wǎng)站建設(shè)網(wǎng)站內(nèi)鏈域名注冊(cè)App開(kāi)發(fā)外貿(mào)網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

網(wǎng)站優(yōu)化排名