當前位置:首頁 » 存儲配置 » 什麼是事務存儲

什麼是事務存儲

發布時間: 2024-08-10 08:08:06

『壹』 mysql中事務和存儲過程的區別

存儲過程是:
通過一系列的SQL語句, 根據傳入的參數(也可以沒有), 通過簡單的調用,
完成比單個SQL語句更復雜的功能, 存儲在資料庫伺服器端,只需要編譯過一次之後再次使用都不需要再進行編譯。主要對存儲的過程進行控制。

事務是一系列的數據更改操作組成的一個整體。一旦事務中包含的某操作失敗或用戶中止,用戶可以控制將事務體中所有操作撤消,返回事務開始前的狀態。
事務中的操作是一個整體,要麼整體完成,要麼全部不做。從而保證了數據的完整性。
Mysql中,MyISAM存儲引擎不支持事務,InnoDB支持。

兩者都是資料庫中非常重要的知識。

『貳』 Mysql中的事務是什麼如何使用



什麼是事務?

事務是邏輯上的一組操作,組成這組操作的各個單元,要不全都成功要不全都失敗,這個特性就是事務

注意:mysql數據支持事務,但是要求必須是innoDB存儲引擎

解決這個問題:

mysql的事務解決這個問題,因為mysql的事務特性,要求這組操作,要不全都成功,要不全都失敗,這樣就避免了某個操作成功某個操作失敗。利於數據的安全

如何使用:

(1)在執行sql語句之前,我們要開啟事務 start transaction;

(2)正常執行我們的sql語句

(3)當sql語句執行完畢,存在兩種情況:

1,全都成功,我們要將sql語句對資料庫造成的影響提交到資料庫中,committ

2,某些sql語句失敗,我們執行rollback(回滾),將對資料庫操作趕緊撤銷


(注意:mysql數據支持事務,但是要求必須是innoDB存儲引擎)
mysql> create table bank(name varchar(20),money decimal(5,1))engine=innodb defau
lt charset=utf8;

mysql> inset into bank values('shaotuo',1000),('laohu',5000);

mysql> select*from bank;
+---------+--------+
| name | money |
+---------+--------+
| shaotuo | 1000.0 |
| laohu | 5000.0 |
+---------+--------+

------沒有成功「回滾」執行rollback
mysql> start transaction; //開啟事務
Query OK, 0 rows affected (0.00 sec)

mysql> update bank set money=money+500 where name='shaotuo'
Query OK, 1 row affected (0.00 sec)
Rows matched: 1 Changed: 1 Warnings: 0

mysql> update bank set moey=money-500 where name='laohu'
ERROR 1054 (42S22): Unknown column 'moey' in 'field list'
mysql> rollback; //只要有一個不成功,執行rollback操作
Query OK, 0 rows affected (0.01 sec)

mysql> select*from bank;
+---------+--------+
| name | money |
+---------+--------+
| shaotuo | 1000.0 |
| laohu | 5000.0 |
+---------+--------+
------成功之後 進行commit操作
mysql> start transaction; //開啟事務
Query OK, 0 rows affected (0.00 sec)

mysql> update bank set money=money+500 where name='shaotuo'
Query OK, 1 row affected (0.01 sec)
Rows matched: 1 Changed: 1 Warnings: 0

mysql> update bank set money=money-500 where name='laohu'
Query OK, 1 row affected (0.00 sec)
Rows matched: 1 Changed: 1 Warnings: 0

mysql> commit; //兩個都成功後執行commit(只要不執行commit,sql語句不會對真實的資料庫造成影響)
Query OK, 0 rows affected (0.05 sec)

mysql> select*from bank;
+---------+--------+
| name | money |
+---------+--------+
| shaotuo | 1500.0 |
| laohu | 4500.0 |
+---------+--------+


您可能感興趣的文章:MySQL存儲過程例子(包含事務,輸出參數,嵌套調用)MySql的事務使用與示例詳解mysql實現事務的提交和回滾實例mysql 鎖表鎖行語句分享(MySQL事務處理)通過唯一索引S鎖與X鎖來了解MySQL死鎖套路MySQL死鎖套路之唯一索引下批量插入順序不一致由不同的索引更新解決MySQL死鎖套路當Mysql行鎖遇到復合主鍵與多列索引詳解MySql 知識點之事務、索引、鎖原理與用法解析


『叄』 事務和存儲過程的區別

事務是用戶定義的一個資料庫操作序列,這些操作要麼全做,要麼全不做,是一個不可分割的工作單位
存儲過程是一組為了完成特定功能的SQL語句集(或者自定義資料庫操作命令集)

『肆』 關於存儲過程與事務

這兩個概念可以說是兩個范疇的概念,事務是資料庫操作范疇的概念,保證資料庫數據的完整性和一致性;存儲過程是高級程序設計中模塊化設計思想的重要內容。

事務是包含一組修改(插入、更新和刪除)的工作的邏輯單位。事務的操作要麼被保存到資料庫commit,要麼回滾rollback,事務中的所有修改要麼全部提交,要麼什麼也不做,這樣保證了資料庫中數據的完整性和一致性。

資料庫操作中為了完成一個完整的資料庫任務,從而引進高級程序的設計要素。過程就是高級程序設計語言中的模塊概念,將一些內部聯系的命令組成一個個過程,通過參數在過程間傳遞數據來完成一個完整的資料庫任務,這就是模塊化設計思想的重要內容。

有的時候可以把一個過程看作一個事務,但是有的過程運行過程中因為滿足某些條件而從過程中跳出,這時就不能把過程看作事務;反之,一個事務可能是一個過程,也可能一個事務中包含對一個或多個過程的調用。

二者概念所述的范疇不同,在資料庫中,是相互聯系相互區別的;而且兩者都是具體的,不是抽象的,因為都可以拿出一段代碼,說它是事務或是存儲過程。

以上是個人理解,希望對你有所幫助。

『伍』 事務是指什麼

1、事務就是指准備要做的或所做的事情,在計算機語言中是指訪問並可能更新資料庫中各種數據項的一個程序單元,也是資料庫運行中的邏輯工作單位,由DBMS中的事務管理子系統負責事務的處理。

2、提交事務:Commit Transaction,成功的結束,將所有的DML語句操作歷史記錄和底層硬碟數據來一次同步

3、事務回滾:End Transaction,失敗的結束,將所有的DML(insert、update、delete)語句操作歷史記錄全部清空。

所謂回滾事務,簡單來說就是當一個事務的某一個操作發生問題時,整個事務可以回滾掉,就像沒有做任何操作一樣,換言之當發生錯誤或事務被取消,則回滾事務。

當開啟事務之後,所有的操作都會被存儲在事務日誌中,而只有當我們進行提交事務的操作後,才會將我們更新的數據同步到數據表中。

(5)什麼是事務存儲擴展閱讀

在 MySQL 命令行的默認設置下,事務都是自動提交的,即執行 SQL 語句後就會馬上執行COMMIT 操作。因此要顯式地開啟一個事務務須使用命令 BEGIN 或START TRANSACTION,或者執行命令 SET AUTOCOMMIT=0,用來禁止使用當前會話的自動提交。

和事務相關的語句

開啟事務:Start Transaction

事務結束:End Transaction

提交事務:Commit Transaction

回滾事務:Rollback Transaction

熱點內容
訪問內網計算機 發布:2024-11-25 12:37:53 瀏覽:968
蘋果文件夾名字大全 發布:2024-11-25 12:28:03 瀏覽:589
ipad上b站緩存分屏 發布:2024-11-25 12:27:59 瀏覽:980
資料庫日誌文件查看 發布:2024-11-25 12:17:28 瀏覽:47
騰訊視頻明明緩存了看不了 發布:2024-11-25 12:08:01 瀏覽:181
存儲區域網路分布 發布:2024-11-25 12:07:12 瀏覽:388
安卓怎麼用湯不熱 發布:2024-11-25 11:49:06 瀏覽:843
java線程調用 發布:2024-11-25 11:42:45 瀏覽:844
識地圖演算法 發布:2024-11-25 11:31:10 瀏覽:20
楊輝三角c語言程序一維數組 發布:2024-11-25 11:30:30 瀏覽:214