事务的理解和使用

在关系型数据库中,事务扮演着很重要的角色。
概念:事务是并发控制的基本单位,其中的操作要么全部执行,要么全部不执行。
事务有四个特性:ACID,接下来我们一起看看事务的这四个特性

原子性

操作本身不具有原子性,一个操作可以再分为多个操作,当该操作中一步出现错误时,整个操作都无法继续执行,而已经执行的操作可能会造成数据更新的丢失或者错误。
事务的原子性将一系列数据库操作集中在一起,全部要么执行要么不执行,不会出现上述执行一半产生的错误。

持久性

数据库要求数据被写入后能够安全持久地存储在数据库中,当事务被提交后就无法再次回滚,唯一能够撤回已经提交事务的方式是创建一个相反的事务对原操作进行返回,这也是事务持久性的体现

隔离性

隔离性指当多个用户并发访问数据库时,比如操作同一张表时,数据库为每一个用户开启的事务不能被其他事务的操作干扰,多个并发事务之间要相互隔离:举例来说:当a和b同时想要买一张票时,a和b需要对同一张票进行操作,但是不能出现a和b买到同一张票的情况,即a和b对同一张票的状态做了修改。

一致性

在理解数据库的一致性时,会产生让人混淆的状况,原因是数据库中事务的一致性其实包含两个一致性,一个是ACID中的一致性,一个CAP定义的一致性。那我们分别看一下这两个一致性:
ACID一致性:如果一个事务原子地在一个一致的数据库中独立运行,那么在它执行后,数据库的状态一定是一致的。简单来说,一是事务的执行前后不会违背对数据库本身的一些约束比如:完整性约束,主键约束,对数据库的写入操作都是合法的。二是事务在逻辑上是正确的,比如银行转账不可能只扣钱不加钱。
CAP一致性:
分布式系统中各个节点对于同一数据的拷贝具有相同的值

事务的使用:

  • START TRANSACTION或BEGIN开始新的事务
  • COMMIT提交当前事务,使其更改永久化
  • ROLLBACK回滚当前事务,取消之前的操作
  • SET autocommit 禁用或者启动当前会话的默认自动提交模式
    默认情况下,MySQL在启用自动提交模式的情况下运行。意味着只要执行更新或修改表的语句,MySQL就会将更新持久地存储在磁盘上,无法回滚更改。
    如果要显式禁用自动提交模式,可以使用下面语句:
SET autocommit = 0;

接下来我们看一下使用事务的例子:
给goods和employee表中添加数据

BEGIN;
INSERT INTO goods VALUES (5,"apple","food",9);
INSERT INTO employee VALUES (6,"SEOEN"),(7,"MINYOUK");
COMMIT;

最后我们再重点看一下事务的ACID特性中的隔离性
当同时开启多个事务操作数据库中的数据时,数据库系统要对不同的事务进行隔离,保证不同的用户获取数据的准确性。

如果没有隔离会发生的三个问题

脏读

一个事务处理过程中读取了另一个未提交的事务的数据。

不可重复读

对于某个数据,一个事务范围内多次查询却返回了不同的结果,这是由于在查询的间隔,另外的事务修改并提交了数据。

幻读

在一个事务中读取到了别的事务插入的数据,导致前后不一致。

事务的隔离级别以及效果:

举例:

  1. 在未提交读的隔离等级下,脏读,不可重复读,幻读出现的情况:
    事务开始前score表中的数据:



    事务1:

BEGIN;
SELECT @@transaction_isolation;
SET SESSION TRANSACTION isolation level read uncommitted;
SELECT @@transaction_isolation;
SELECT * FROM score;
SELECT * FROM score;
COMMIT;

事务2

BEGIN;
SELECT @@transaction_isolation;
UPDATE score SET score = score + 5 WHERE id= 1;
DELETE FROM score WHERE id = 4;
SELECT * FROM score;

执行事务2给score表id为1的成绩加5后结果:



执行事务2删除id为4的数据查询结果:



我们可以看到在上面的例子中,隔离等级设为未提交读,当事务2中操作未提交时就在事务1中读到了事务2操作生效后的数据,而实际上事务2中的操作没有提交也就是还没有更新到数据库中。同时在事务1中两次查询到了不同的结果。出现了脏读和不可重复读的现象。
  1. 在已提交读的隔离等级下是否会出现脏读,不可重复读的情况:
    事务开始前的数据库数据:



    事务1

BEGIN;
SELECT @@transaction_isolation;
SET SESSION TRANSACTION isolation level read committed;
SELECT @@transaction_isolation;
SELECT * FROM score;
SELECT * FROM score;
COMMIT;

事务2

BEGIN;
SELECT @@transaction_isolation;
SET SESSION TRANSACTION isolation level read committed;
SELECT @@transaction_isolation;
UPDATE score SET score = score + 5 WHERE id= 1;
SELECT * FROM score;
COMMIT;

打开事务1和2两个事务,将其隔离等级设为已提交读,在事务2中对id为1的成绩加5,在事务2中查询结果加5,事务1中查询结果没变。我们将事务2提交后再在事务1中查询看到结果发生了变化。即在隔离等级为已提交读的情况下不会出现可重复读的现象。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,271评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,275评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,151评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,550评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,553评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,559评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,924评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,580评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,826评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,578评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,661评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,363评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,940评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,926评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,156评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,872评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,391评论 2 342

推荐阅读更多精彩内容