## 事務
* 當一個業務邏輯需要多個sql完成時,如果其中某條sql語句出錯,則希望整個操作都退回
* 使用事務可以完成退回的功能,保證業務邏輯的正確性
* 事務四大特性(簡稱ACID)
* 原子性(Atomicity):事務中的全部操作在數據庫中是不可分割的,要么全部完成,要么均不執行
* 一致性(Consistency):幾個并行執行的事務,其執行結果必須與按某一順序串行執行的結果相一致
* 隔離性(Isolation):事務的執行不受其他事務的干擾,事務執行的中間結果對其他事務必須是透明的
* 持久性(Durability):對于任意已提交事務,系統必須保證該事務對數據庫的改變不被丟失,即使數據庫出現故障
* 要求:表的類型必須是innodb或bdb類型,才可以對此表使用事務
* 查看表的創建語句
~~~
show create table students;
~~~
* 修改表的類型
~~~
alter table '表名' engine=innodb;
~~~
* 事務語句
~~~
開啟begin;
提交commit;
回滾rollback;
~~~
## 示例1
* 步驟1:打開兩個終端,連接mysql,使用同一個數據庫,操作同一張表
~~~
終端1:
select * from students;
------------------------
終端2:
begin;
insert into students(sname) values('張飛');
~~~
* 步驟2
~~~
終端1:
select * from students;
~~~
* 步驟3
~~~
終端2:
commit;
------------------------
終端1:
select * from students;
~~~
## 示例2
* 步驟1:打開兩個終端,連接mysql,使用同一個數據庫,操作同一張表
~~~
終端1:
select * from students;
------------------------
終端2:
begin;
insert into students(sname) values('張飛');
~~~
* 步驟2
~~~
終端1:
select * from students;
~~~
* 步驟3
~~~
終端2:
rollback;
------------------------
終端1:
select * from students;
~~~
- mysql
- 1.創建庫和表
- 1.1.數據庫簡介
- 1.2.安裝管理
- 1.3.數據完整性
- 1.4.命令腳本操作
- 2.查詢
- 2.1.條件
- 2.2.聚合
- 2.3.分組
- 2.4.排序
- 2.5.分頁
- 3.高級
- 3.1.關系
- 3.2.連接
- 3.3.自關聯
- 3.4.子查詢
- 3.5.內置函數
- 3.6.視圖
- 3.7.事務
- 4.與python交互
- 4.1.交互類型
- 4.2.增改刪
- 4.3.查詢
- 4.4.封裝
- 4.5.用戶登錄
- Nosql簡介
- mongodb
- 1.基本操作
- 1.1.環境安裝
- 1.2.數據庫操作
- 1.3.集合操作
- 1.4.數據類型
- 1.5.數據操作
- 1.6.數據查詢
- 1.6.1.Limit與Skip
- 1.6.2.投影
- 1.6.3.排序
- 1.6.4.統計個數
- 1.6.5.消除重復
- 2.高級操作
- 2.1.聚合aggregate
- 2.1.1.$group
- 2.1.2.$match
- 2.1.3.$project
- 2.1.4.$sort
- 2.1.5.$limit,$skip
- 2.1.6.$unwind
- 2.2.安全
- 2.3.復制(副本集)
- 2.4.備份和恢復
- 2.5.與python交互
- redis
- 1.基本配置
- 2.數據操作
- 2.1.string
- 2.2.鍵命令
- 2.3.hash
- 2.4.list
- 2.5.set
- 2.6.zset
- 4.高級
- 4.1.發布訂閱
- 4.2.主從配置
- 5.與python交互
- 6.login登陸完善