MySQL入门篇(01)

1、MySQL数据库的基本结构


MySQL数据库基本结构

最上层的客户端层负责处理链接处理和授权认证,安全等功能。

第二层架构是MySQL中的核心层,MySQL大多数核心功能都在这一层搞定。包括查询解析,优化,缓存以及MySQL所有的内置函数。所有的跨存储引擎的功能都在这一层实现。

第三层是MySQL所有的存储引擎。每一种存储引擎都有其不同的地方,也有其优势和劣势。存储引擎除了InnoDB以外都不会去解析SQL。InnoDB因为涉及到外键,所以需要解析SQL。

2、MySQL的并发控制

无论何时,只要涉及到读写操作都会涉及到并发问题。日志,邮件,excel等等都会有这样的问题。我之前写过一个功能是解析日志判断接口中日志打印的参数和传递的参数是否一致。最开始我没有考虑到这个问题,写了个线程池直接多线程给接口发请求。结果打印出来的日志全是乱七八糟的,日志格式也被改变了。

MySQL作为数据库,肯定不能允许并发问题的发生。不可能两个人同时对一条数据进行修改会出现很多种不同的结果,那样就乱套了。

读写锁:

我们常用的邮件功能,如果两个人同时阅读同一封邮件是完全没有问题的。但是如果一个人在阅读一封邮件,但是同时另外一个人修改了这封邮件,那么就会导致读邮件的人可能会看到不同的结果。有可能是空白邮件,也有可能是没有修改以前的邮件,还有可能乱码等各种问题。数据库也存在同样的问题。

解决这类问题的最经典的方法就是加共享锁(读锁)和排它锁(写锁)。

共享锁又称读锁。读一个数据的时候多少个对象同时读取都无所谓,都可以同时读取数据,互不干扰。

排它锁又称写锁。一个写锁会阻塞其他的共享锁和排它锁。在有对象在进行写的操作时,数据库会将数据锁死,不允许读也不会允许别的用户对其修改。

粒度锁:

除了读写锁,MySQL还有一种锁机制叫做粒度锁。读写锁虽然可以解决读写矛盾问题,但是还有个很严重的问题就是我们应该锁住多大的范围?是只要有一条内容被修改我们就锁住整个数据库不让读还是锁住整个表又或者仅仅只是锁住被修改的那一行不让读?这个就涉及到粒度锁。

我们最希望的方式是尽量精确的锁定被修改的地方而不是锁定所有资源,这样可以支持更高的并发量,只要修改的数据不互相冲突即可。

但是问题是加锁也需要消耗资源。锁的各种操作,包括获得锁,检查锁是否被释放,释放锁等等操作,都会大幅度的增加系统的消耗。所以采取哪一种的锁策略,也需要在锁的开销和数据安全之间寻求平衡。

MySQL最重要的两种锁策略分别是表锁和行级锁。

表锁是MySQL中开销最小的锁策略。当一张表中有一行被更改时,当前表就不再允许查询和修改。一个用户在对表进行写操作时需要首先获取表的排它锁。当其获取了排它锁,别人就不能再对这张表进行访问,除非他修改完该表并且释放了锁。

行级锁可以最大程度的支持并发处理,但是他也是锁消耗最大的锁。行级锁只会获取需要修改的行的排它锁,整张表的其余行依然可以进行访问。

3、MySQL的事务

说明事务最好的方式就是转账。

如果A要给B转账200元钱。从数据库的操作来看就是

1. 开始事务

2. A账户减少200元

3. B账户增加200元

4. 提交事务

当第三条执行失败时,事务没有被提交,所以会直接回滚到执行事务以前。A的账户不会减少200元。

事务的四大特性:原子性,一致性,隔离性,持久性

原子性:一个事务必须被视为不可分割的最小单元,整个事务必须全部提交成功或者全部提交失败。

一致性:数据库总是从一个一致性的状态转换到另外一个一致性的状态。

隔离性:通常来说一个事务在没有提交以前对于别的事务来说是不可见的。前面转账的例子如果在执行B账户增加200元操作的同时另一个事务查询了A的账户,A的账户应该还是未减少之前的状态。

持久性:一旦事务提交,那么数据就会被永久的保存到数据库中。这是哪怕是系统崩溃了,死机了,数据也不会丢失。但是这也只是理论上,否则也不会需要做备份了。

隔离性实际上比想象的要复杂的多得多。在SQL中定义了四中隔离级别,级别越低的并发能力越强,当然安全性也就越差。级别越高的并发能力越差,安全性也越强。

四大隔离级别:未提交读,提交读(不可重复读),可重复读,可串行化

未提交读:在这个隔离级别下事务里面未提交的部分别的事务也可以看到,这又被称之为脏读。这个级别会导致非常多的问题,比如查询后根据查询到的数据修改数据,就会导致数据错误。在性能上来说这个级别的并发性能是最好的,但是基本上不用,因为太不安全。

提交读(不可重复读):大多数的数据库的默认事务隔离级别都是不可重复读,但是MySQL不是。不可重复读满足了前面隔离性的简单定义,一个事务如果没有被提交,那么就不会被别的事务读取结果。但是同一个事务中两次读取同一个数据可能获取的结果不一样。

可重复读:该级别可以保证多次读取同样记录的结果是一样的,MySQL默认的就是该隔离级别,但是其无法解决幻读的问题。

可串行化:可串行化是隔离级别的最高级别,它强制所有的事务必须串行执行,避免了幻读的问题,但是效率太低,一般也不会用。


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