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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

事务的概述

發(fā)布時(shí)間:2023/12/3 编程问答 50 豆豆
生活随笔 收集整理的這篇文章主要介紹了 事务的概述 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

1.基本概念

  • 將一條或者多條SQL看成一個(gè)整體,要么同時(shí)執(zhí)行成功要么同時(shí)執(zhí)行失敗,這就是事務(wù)。


    事務(wù)舉例:
    張三給李四轉(zhuǎn)賬500元錢,需要讓三賬戶的余額-500,李四的賬戶余額+500,轉(zhuǎn)賬是一個(gè)連續(xù)的過程,要么同時(shí)成功,要么同時(shí)失敗。不能出現(xiàn)張三轉(zhuǎn)出了500塊,而李四沒收到的情況,這將是很嚴(yán)重的問題。

2.事務(wù)的基本使用

執(zhí)行SQL語句之前開啟事務(wù),執(zhí)行后沒異常就提交,有異常就回滾

<1>開啟事務(wù):在執(zhí)行一組sQL操作之前開始事務(wù),start transaction;
提交了之后是不是不能回滾

<2>提交事務(wù):在一組sQL執(zhí)行成功之后提交事務(wù),commit;

如果開啟事務(wù)不提交,那么默認(rèn)就是回滾【斷開連接】
<3>回滾事務(wù):在一組SQL執(zhí)行出現(xiàn)異常之后回滾事務(wù),rollback;

舉例【執(zhí)行后,發(fā)現(xiàn)查詢結(jié)果出錯(cuò)則回滾,正確則提交】:

-- 張三給李四轉(zhuǎn)賬500元-- 開啟事務(wù) START TRANSACTION;-- 1.張三賬戶-500 UPDATE account SET money=money-500 WHERE NAME='張三';出錯(cuò)了...-- 2.李四賬戶+500 UPDATE account SET money=money+500 WHERE NAME='李四';-- 回滾事務(wù) ROLLBACK;-- 提交事務(wù) COMMIT;

補(bǔ)充–try里面使用commit提交事務(wù),catch里面使用rollback回滾事務(wù)

3.事務(wù)的提交方式

1代表自動(dòng)提交 0代表手動(dòng)提交[COMMIT;]

  • 查詢事務(wù)提交方式:SELECT @@AUTOCOMMIT;
SELECT @@autocommit;

  • 修改事務(wù)提交方式:SET @@AUTOCOMMIT=數(shù)字;
SET @@autocommit = 1; SELECT @@autocommit;

4.事務(wù)的四大特征(ACID)

<1> 原子性(Atomicity)

原子性是指事務(wù)包含的所有操作要么全部成功,要么全部失敗回滾。

因此事務(wù)的操作如果成功就必須要完全應(yīng)用到數(shù)據(jù)庫,如果操作失敗則不能對數(shù)據(jù)庫有任何影響。

<2> 一致性(Consistency)

一致性是指事務(wù)必須使數(shù)據(jù)庫從一個(gè)一致性狀態(tài)變換到另一個(gè)一致性狀態(tài)。

也就是說一個(gè)事務(wù)執(zhí)行之前和執(zhí)行之后都必須處于一致性狀態(tài)。

<3> 隔離性(isolcation)

隔離性是當(dāng)多個(gè)用戶并發(fā)訪問數(shù)據(jù)庫時(shí),比如操作同一張表時(shí),數(shù)據(jù)庫為每一個(gè)用戶開啟的事務(wù)。

不能被其他事務(wù)的操作所干擾,多個(gè)并發(fā)事務(wù)之間要相互隔離。

<4> 持久性(durability)

持久性是指一個(gè)事務(wù)一旦被提交了,那么對數(shù)據(jù)庫中的數(shù)據(jù)的改變就是永久性的。

即便是在數(shù)據(jù)庫系統(tǒng)遇到故障的情況下也不會(huì)丟失提交事務(wù)的操作。

5.事務(wù)的隔離級(jí)別

  • 多個(gè)事務(wù)之間是隔離的,相互獨(dú)立的。但是如果多個(gè)事務(wù)操作同一批數(shù)據(jù),則會(huì)引發(fā)一些問題,設(shè)置不同的隔離級(jí)別就可以解決這些問題。
  • 產(chǎn)生條件是要在兩個(gè)新連接中操作【如兩臺(tái)電腦,獲取一臺(tái)電腦連接數(shù)據(jù)庫兩次】,不是一個(gè)連接中的兩個(gè)查詢窗口。

<1>設(shè)置隔離級(jí)別
可重復(fù)讀:兩次讀取的數(shù)據(jù)一樣
不可重復(fù)讀:兩次讀取的數(shù)據(jù)不一樣【問題:多人操作時(shí)所看到的數(shù)據(jù)有差異】

<2>存在的問題

<3>查詢隔離級(jí)別以及設(shè)置隔離級(jí)別

  • 數(shù)據(jù)庫查詢隔離級(jí)別:
    select @@tx_isolation;

  • 數(shù)據(jù)庫設(shè)置隔離級(jí)別(修改后需要重新連接):
    set global transaction isolation level 級(jí)別字符串;

總結(jié)

以上是生活随笔為你收集整理的事务的概述的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

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