# 事務(wù)
用途:
a -> b 轉(zhuǎn)賬
1. a的賬戶的錢 先扣去掉一部分? update person set money = money - 10 where name = a;
2. b的賬戶的錢 增加a扣除的部分? update person set money = money + 10 where name = b;
上面兩個(gè)條sql語(yǔ)句 要求全成功绑警, 要么都失敗樊展, 這個(gè)時(shí)候我們就可以把這兩個(gè)sql語(yǔ)句放到同一事務(wù)中
支持情況: 只有Innodb 引擎的才支持, 常見的引擎有兩個(gè)(Innodb, MyISAM)
事務(wù)的特征(ACID):
原子性,每個(gè)事務(wù)是一個(gè)最小的不可分割單元
一致性坏瘩,數(shù)據(jù)執(zhí)行執(zhí)行完事務(wù)之后,數(shù)據(jù)要保持一致(正確)
隔離性茫死,事務(wù)和事務(wù)之間是隔離的丰嘉,相互不影響(4中隔離級(jí)別)
持久性,一旦事務(wù)提交成功枣申,數(shù)據(jù)發(fā)生了不可逆的變化
事務(wù)執(zhí)行的語(yǔ)句:
select 不需要事務(wù)的
插入售葡,更新,刪除 默認(rèn)情況下一條sql就是一個(gè)事務(wù)忠藤,事務(wù)默認(rèn)是開啟自動(dòng)提交的
# sql語(yǔ)句的執(zhí)行 (SET AUTOCOMMIT=0), 把自動(dòng)提交給取消
開始事務(wù) begin
執(zhí)行sql (如果中間錯(cuò)誤了挟伙,執(zhí)行rollback)
提交事務(wù) commit
# 存檔(savepoint)
# mysql的隔離級(jí)別
#查看mysql 默認(rèn)的隔離級(jí)別
@@global.transaction_isolation 系統(tǒng)的隔離級(jí)別
@@transaction_isolation 當(dāng)前會(huì)話的隔離級(jí)別
select @@global.transaction_isolation,@@transaction_isolation;
# 隔離級(jí)別
read uncommitted (讀未提交)? --> 導(dǎo)致臟讀,讀取到其他事務(wù)沒有提交的數(shù)據(jù),如果其他萬(wàn)一回滾模孩,這是數(shù)據(jù)無(wú)效尖阔。
REPEATABLE-READ(默認(rèn)的隔離級(jí)別,讀已提交) ->
解決臟讀榨咐,導(dǎo)致不可重復(fù)讀取介却,在同一事務(wù)中前后兩次查詢的數(shù)量可能不一致。
repeatable-read (可重復(fù)讀) ->
解決不可重復(fù)讀块茁,導(dǎo)致幻讀
1. 在A中開啟事務(wù)? ? 2. 在B中開啟事務(wù)
3. 查詢一下叫'李四'學(xué)生? 4. 插入‘李四’的學(xué)生
5. 提交事務(wù)
6. 查詢‘李四’,李四不存在
7 插入一下李四齿坷,有插入不成功(name要唯一)
serializable(串行化)
解決幻讀
1. 一個(gè)事務(wù)一個(gè)的執(zhí)行,事務(wù)都不并發(fā)数焊,沒有任何問題永淌,但是會(huì)到性能下降
# 隔離界別越高,性能越下降(采用默認(rèn)的隔離級(jí)別就可以了)
# 修改隔離級(jí)別
set session transaction isolation level read uncommitted
set session transaction isolation level read committed
set session transaction isolation level? repeatable read
# 視圖
View
應(yīng)用場(chǎng)景
1. 數(shù)據(jù)關(guān)聯(lián)很復(fù)雜
2. 有一些數(shù)據(jù)不能想某些人看 (讓別人通過視圖查詢數(shù)據(jù))
什么是視圖
一張?zhí)摂M表昌跌,有字段等仰禀,但是不真正的存儲(chǔ)數(shù)據(jù)照雁,對(duì)查詢結(jié)果的一個(gè)引用蚕愤,在使用視圖的時(shí)候,我們以查詢?yōu)橹鹘任茫静簧喜蛔龈缕加眨砑樱瑒h除操作污呼。
1. 查詢 張三的人裕坊,他的各門課程成績(jī), 按照降序進(jìn)行排序
select st.s_name sname, cu.c_name cname, sc.s_score score from student st left join score sc on st.s_id = sc.s_id left join course cu on cu.c_id = sc.c_id where st.s_name = '錢電' order by score desc;
# 可以使用視圖
1. create view temp as select st.s_id sid,st.s_name sname, cu.c_name cname, sc.s_score score from student st left join score sc on st.s_id = sc.s_id left join course cu on cu.c_id = sc.c_id
2. select * from temp where sname = '趙雷' order by score desc;
# 注意: 如果希望更新視圖燕酷,視圖和數(shù)據(jù)表的關(guān)系一一對(duì)應(yīng)的籍凝,如果希望做更新和插入周瞎,直接在原表上進(jìn)行
# 視圖不屬于這一次會(huì)話, 一次創(chuàng)建之后可以一直使用
# 視圖是對(duì)真實(shí)數(shù)據(jù)表的引用饵蒂,當(dāng)真實(shí)數(shù)據(jù)表發(fā)生變化的時(shí)候声诸,視圖的數(shù)據(jù)也跟著發(fā)生變化。