Mysql交易處理

來源:互聯網
上載者:User

標籤:

Mysql中MyISAM儲存引擎不支援事務,InnoDB和BDB支援事務

 

事務是一組連續的資料庫操作,而這組操作是不可分割的,也就是說這組操作要麼全執行成功,要不就全部執行失敗(實際不執行)。

事務有以下四個標準屬性的縮寫ACID,通常被稱為:

原子性: 確保工作單元內的所有操作都成功完成,否則事務將被中止在故障點,和以前的操作將復原到以前的狀態。

一致性: 確保資料庫正確地改變狀態後,成功提交的事務。

隔離性: 使事務操作彼此獨立的和透明的。

持久性: 確保提交的事務的結果或效果的系統出現故障的情況下仍然存在。

 

 MYSQL的交易處理主要有兩種方法。
   1、用begin,rollback,commit來實現
       begin 開始一個事務
       rollback 交易回復
       commit  事務確認
   2、直接用set來改變mysql的自動認可模式
       MYSQL預設是自動認可的,也就是你提交一個QUERY,它就直接執行!我們可以通過
       set autocommit=0  禁止自動認可
       set autocommit=1 開啟自動認可
       來實現事務的處理。
但注意當你用 set autocommit=0 的時候,你以後所有的SQL都將做為交易處理,直到你用commit確認或rollback結束,注意當你結束這個事務的同時也開啟了個新的事務!按第一種方法只將當前的作為一個事務!

 

走一遍:

先建立一個innodb表

create table test(id int(9))ENGINE=INNODB;

操作:

begin;insert into test value(1);insert into test value(2);commit;

測試一下

begin;insert into test value(3);select * from test;(此時結果中有3);rollback;select * from test;(此時結果中無3);

 

Mysql交易處理

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.