欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mysql事務(wù)管理操作詳解

 更新時間:2020年04月10日 10:04:02   作者:隨風(fēng)行云  
這篇文章主要介紹了mysql事務(wù)管理操作,結(jié)合實例形式詳細(xì)分析了mysql事務(wù)管理相關(guān)特性、原理及回滾操作注意事項,需要的朋友可以參考下

本文實例講述了mysql事務(wù)管理操作。分享給大家供大家參考,具體如下:

本文內(nèi)容:

  • 什么是事務(wù)管理
  • 事務(wù)管理操作
  • 回滾點
  • 默認(rèn)的事務(wù)管理

首發(fā)日期:2018-04-18


什么是事務(wù)管理:

  • 可以把一系列要執(zhí)行的操作稱為事務(wù),而事務(wù)管理就是管理這些操作要么完全執(zhí)行,要么完全不執(zhí)行(很經(jīng)典的一個例子是:A要給B轉(zhuǎn)錢,首先A的錢減少了,但是突然的數(shù)據(jù)庫斷電了,導(dǎo)致無法給B加錢,然后由于丟失數(shù)據(jù),B不承認(rèn)收到A的錢;在這里事務(wù)就是確保加錢和減錢兩個都完全執(zhí)行或完全不執(zhí)行,如果加錢失敗,那么不會發(fā)生減錢)。
  • 事務(wù)管理的意義:保證數(shù)據(jù)操作的完整性。
  • mysql中并不是所有的數(shù)據(jù)引擎都支持事務(wù)管理的,只有innodb支持事務(wù)管理。

事務(wù)管理的特性:

  • 原子性:事務(wù)的整個操作是一個整體,不可以分割,要么全部成功,要么全部失敗。
  • 一致性:事務(wù)操作的前后,數(shù)據(jù)表中的數(shù)據(jù)沒有變化。
  • 隔離性:事務(wù)操作是相互隔離不受影響的。
  • 持久性:數(shù)據(jù)一旦提交,不可改變,永久的改變數(shù)據(jù)表數(shù)據(jù)。

事務(wù)管理操作:

  • 開啟事務(wù)管理:開啟之后,下面的sql語句并不會馬上執(zhí)行并把結(jié)果寫到表中,而是會寫到事務(wù)日志中。
    • start transaction;
  • 回退操作:回退會清掉開始事務(wù)管理之后寫到事務(wù)日志中的內(nèi)容,即恢復(fù)到開啟事務(wù)管理之前。
    • 語法:rollback;
    • 注意:回退操作只是回退"寫"的內(nèi)容,對于普通的讀表select語句不能回退。
  • 事務(wù)提交:將sql語句的結(jié)果寫到數(shù)據(jù)表中。
    • 語法:commit:

實驗表:

create table bankaccount(id int primary key auto_increment,name varchar(15),money int);
insert into bankaccount(name,money) values("Jobs",2000);
insert into bankaccount(name,money) values("Bill",3000);

image

image

補充:

  • 當(dāng) commit 或 rollback 語句執(zhí)行后,事務(wù)會自動關(guān)閉(將來的更改會隱含提交)。
  • 鎖機制:在事務(wù)操作一個表時,如果使用索引來取值,那么會鎖定到對應(yīng)行;如果沒有使用索引來取值,那么會鎖定整個表。鎖定之后其他連接無法操作指定行或表。

回滾點:

  • 回滾點可以指定rollback回退的位置【比如現(xiàn)在打了100條命令,發(fā)現(xiàn)第81打錯了,如果回滾到打了81命令之前一點而不是回滾到開啟事務(wù)之前就可以節(jié)省下很多時間?!?/li>
  • 語法:
    • 創(chuàng)建回滾點:savepoint 回滾點名;
    • 回滾到回滾點:rollback to 回滾點名;

image

補充:

  • 回滾點在事務(wù)管理關(guān)閉(rollback或commit之后)之后失效,不要在事務(wù)之外使用回滾點。

默認(rèn)的事務(wù)管理:

  • 默認(rèn)情況下,mysql的事務(wù)管理是關(guān)閉(自動事務(wù))的,語句的結(jié)果會馬上寫到數(shù)據(jù)表中。
    • 可以通過show variable like 'autocommit';來查看是否開啟自動事務(wù),值為1為自動事務(wù)已開啟,為0則為關(guān)閉。
  • 關(guān)閉自動事務(wù):set autocommit =0;【關(guān)閉后需要commit來執(zhí)行每一條語句,相當(dāng)于開始了事務(wù)管理】
    • 不過注意的是set autocommit針對的是會話變量,所以這個設(shè)置只在此次會話連接中生效。

更多關(guān)于MySQL相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《MySQL事務(wù)操作技巧匯總》、《MySQL索引操作技巧匯總》、《MySQL常用函數(shù)大匯總》、《MySQL日志操作技巧大全》、《MySQL存儲過程技巧大全》及《MySQL數(shù)據(jù)庫鎖相關(guān)技巧匯總

希望本文所述對大家MySQL數(shù)據(jù)庫計有所幫助。

相關(guān)文章

  • 詳解MySQL alter ignore 語法

    詳解MySQL alter ignore 語法

    這篇文章主要介紹了MySQL alter ignore 語法的相關(guān)資料,幫助大家更好的理解和使用MySQL,感興趣的朋友可以了解下
    2020-11-11
  • mysql一對多關(guān)聯(lián)查詢分頁錯誤問題的解決方法

    mysql一對多關(guān)聯(lián)查詢分頁錯誤問題的解決方法

    這篇文章主要介紹了mysql一對多關(guān)聯(lián)查詢分頁錯誤問題的解決方法,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-09-09
  • MySQL 序列 AUTO_INCREMENT詳解及實例代碼

    MySQL 序列 AUTO_INCREMENT詳解及實例代碼

    這篇文章主要介紹了MySQL 序列 AUTO_INCREMENT詳解及實例代碼的相關(guān)資料,需要的朋友可以參考下
    2017-02-02
  • mysql 批處理文件出錯后繼續(xù)執(zhí)行的實現(xiàn)方法

    mysql 批處理文件出錯后繼續(xù)執(zhí)行的實現(xiàn)方法

    下面小編就為大家?guī)硪黄猰ysql 批處理文件出錯后繼續(xù)執(zhí)行的實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-10-10
  • MySQL安裝后默認(rèn)自帶數(shù)據(jù)庫的作用詳解

    MySQL安裝后默認(rèn)自帶數(shù)據(jù)庫的作用詳解

    這篇文章主要介紹了MySQL安裝后默認(rèn)自帶數(shù)據(jù)庫的作用,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-04-04
  • Java連接MySql的詳細(xì)介紹

    Java連接MySql的詳細(xì)介紹

    本篇文章主要是對Java連接MySql的詳細(xì)介紹。需要的朋友參考下
    2013-04-04
  • mysql中json的使用方式詳解

    mysql中json的使用方式詳解

    這篇文章主要介紹了mysql中json的使用,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-04-04
  • MySQL聯(lián)合查詢實現(xiàn)方法詳解

    MySQL聯(lián)合查詢實現(xiàn)方法詳解

    聯(lián)合查詢union將多次查詢(多條select語句)的結(jié)果,在字段數(shù)相同的情況下,在記錄的層次上進行拼接,這篇文章主要給大家介紹了關(guān)于Mysql聯(lián)合查詢的那些事兒,需要的朋友可以參考下
    2022-11-11
  • Mysql5升級到Mysql5.5的方法

    Mysql5升級到Mysql5.5的方法

    這篇文章主要介紹了Mysql5升級到Mysql5.5的方法的相關(guān)資料,需要的朋友可以參考下
    2016-01-01
  • mysql中的utf8與utf8mb4存儲及區(qū)別

    mysql中的utf8與utf8mb4存儲及區(qū)別

    本文主要介紹了mysql中的utf8與utf8mb4存儲及區(qū)別,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-02-02

最新評論