MySQL事务和存储引擎

TCL:

Transaction Control Language  事务控制语言

事务概念:

一条或一组 SQL 语句组成一个执行单元,其特点是这个单元要么都执行要么都不执行,单元中的每条 SQL 语句相互依赖,形成一个整体,如果某条 SQL 语句执行失败或者出现错误,那么整个单元就会回滚,撤回到事务最初的状态,如果单元中所有的 SQL 语句都执行成功,则事务就顺利执行。

举个栗子:

张三的账户有 1000 元,李四的账户有 1000 元,现在张三准备给李四转账 500,此时执行 SQL 为:

UPDATE tb_account SET balance = 500 WHERE name = '张三';

UPDATE tb_account SET balance = 1500 WHERE name = '李四';

假如在执行完第一条 SQL 语句后,中间出现了错误,执行不到第二条,这就导致了张三的余额变了,而李四的余额没有变。这时就需要事务来解决这个问题,而上面两条 SQL 语句就组成一个执行单元。

事务的特性(ACID):

⑴ 原子性(Atomicity):

    事务是一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生。

⑵ 一致性(Consistency):

    事务必须使数据库从一个一致性状态变换到另外一个一致性状态。比如说刚才的栗子,张三和李四他们在转账之前的余额总和为 2000,经过事务执行之后,他们的余额之和也得是 2000。

⑶ 隔离性(Isolation):

    一个事务的执行不能被其他事务干扰,即一个事务的内部操作及使用的数据对并发的其他事务是隔离的。并发执行的各个事务之间不能互相干扰。

⑷ 持久性(Durability):

    一个事务一旦被提交,它对数据库中数据的改变就是永久性的,后续的其他操作和数据库故障不应该对其有任何影响。

事务的创建:

⑴ 隐式事务:

    事务没有明显的开启和结束的标记,比如 INSERT、UPDATE、DELETE 这些语句都属于隐式事务。

⑵ 显式事务:

    事务具有明显的开启和结束的标记,在使用该事务之前,必须先设置自动提交功能为禁用。

关闭事务自动提交:

通过 SHWO VARIABLES LIKE 'autocommit' 来查看系统的事务是否为自动提交:

由图,自动提交为开启的,所以得先关闭:

由图,通过 SET AUTOCOMMIT = 0 关闭自动提交,而且该操作只对当前事务有效,所以每次使用事务前都得手动关闭。

事务使用步骤:

⑴ 开启事务

    SET AUTOCOMMIT = 0;

    START TRANSACTION;(可选)

⑵ 编写事务中的 SQL 语句(SELECT、INSERT、UPDATE、DELETE)

    SQL 语句1;

    SQL 语句2;

    ...

⑶ 结束事务

① COMMIT;(提交事务)

② ROLLBACK;(回滚事务)

案例:

创建一张表 tb_account:

插入以下数据:

演示张三转账的事务:

再看下 ROLLBACK:

当要把数据都回滚到最初状态时,可以看出记录没有变化,因为 ROLLBACK 只是把记录提交到内存中,并没有提交到磁盘文件,只有当你 COMMIT 之后,数据才到磁盘文件,这时记录才会发生变化。

事务中的并发问题:

对于同时运行的多个事务,当这些事务访问数据库中相同的数据时,如果没有采取必要的隔离机制,将会导致各种并发问题。

导致的问题有以下这几种:

⑴ 脏读

    对于两个事务 T1 和 T2,T2 更新了字段 a 但没有提交,此时 T1 读取的 a 字段就是临时且无效的记录。

⑵ 不可重复读

    对于两个事务 T1 和 T2,T1 读取了 a 字段,然后 T2 更新了该字段之后,T1 再次读取该字段时,两次读取的值不同。

⑶ 幻读

    对于事务 T1 和 T2,T1 从一张表中读取了 a 字段, T2 在该表中插入或者删除了一些新的记录,如果 T1 再次读取同一张表,就会多出或者少几行记录。

对于以上的并发问题,可以通过设置事务的隔离级别来避免。

MySQL 提供了 4 种事务隔离级别:

⑴ READ UNCOMMITTED(读未提交记录)

    允许事务读取未被其他事务提交的变更,脏读,不可重复读和幻读的问题都会出现。

⑵ READ COMMITTED(读已提交记录)

    只允许事务读取已经被其他事务提交的变更,可以避免脏读,但不可重复读和幻读问题仍然可能会出现。

⑶ REPEATABLE READ(可重复读)

    确保事务可以多次从一个字段中读取相同的值,在这个事务持续期间,禁止其他事务对这个字段进行更新,可以避免脏读和不可重复读,但幻读问题仍然存在。

⑷ SERIALIZABLE(串行化)

    确保事务可以从一个表中读取相同的行,在这个事务持续期间,禁止其他事务对该表执行插入,更新和删除操作,所有并发问题都可以避免,但性能十分低下。

MySQL 默认的事务隔离级别为 REPEATABLE READ。

查询当前的隔离级别:

设置当前l连接 MySQL 事务隔离级别:

set session transaction isolation level read uncommitted;

设置系统的全局事务隔离级别:

set global transaction isolation level read uncommitted;

SAVEPOINT 节点名:

设置保存点,只能和 ROLLBACK 一起使用

用法:

查看下表 tb_account 的记录:

现在开启一个事务,删除 id = 3 的记录,然后保存一个节点 a,再删除 id = 4 的记录,查看下结果:

可见,id = 3 的记录已经被删了,而 id = 4 还在表里,因为 ROLLBACK 回滚到了保存点,所以 id = 4 的记录没有被删除。

存储引擎:

概念:

MySQL 可以将数据以不同的技术存在在文件(内存)中,这种技术称之为存储引擎(表类型)。每一种存储引擎使用不同的存储机制、索引技巧、锁定水平,最终提供广泛且不同的功能。

通过命令 SHOW ENGINES 来查看 MySQL 中的存储引擎:

常用存储引擎的特点:

修改存储引擎:

⑴ 通过修改 MySQL 配置文件:

    default-storage-engine = engine

⑵ 通过创建数据表时设置:

    CREATE TABLE tb_name(

    ...

    ...

    ) ENGINE = engine;

⑶ 修改数据表的引擎:

    ALTER TABLE tb_name ENGINE [=] engine_name;

以上为本人的一些学习笔记,如有出错欢迎指正,陆续更新!!!

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

推荐阅读更多精彩内容