深入了解Mysql逻辑架构
作者:晴转阵雨 发布时间:2024-01-24 21:38:58
Mysql现在是大多数公司企业在用的数据库,之所以用Mysql,一点是因为Mysql是开源软件,一些有能力的公司会基于已有的Mysql架构,进行修改、调整改成适合自己公司的业务需要。
一点是因为Mysql免费,相对昂贵的Oracle服务,对于很多刚起步的公司来说,是最适合不过的数据库了。
之所以要认识Mysql的逻辑架构,就好比我们自己在做开发时,首先需要先掌握自己系统用的分层架构,这样在开发的过程中,如果有哪个环节产生问题,就很好排查。认识Mysql的逻辑架构也同理,我们在用Mysql的时候,我们不清楚它什么时候会出现问题,但是当出现问题时(比如优化查询sql,要从哪一步开始),我们可以更清楚的定位问题。
1.Connections 连接器
我们连接Mysql的服务作为客户端连接Mysql服务端,Mysql可以连接各个编程语言平台
2.系统管理和控制工具(Management Serveices & Utilities)
作为Mysql服务的管理和控制工具,比如备份、还原、复制、集群等
3.连接池(Connection Pool)
连接池的主要功能是提供连接认证、线程复用、连接数限制等
4.SQL Interface(SQL接口)
这里主要是接收Mysql 的DML、DDL语句,以及存储过程、视图、触发器等
5.Parse(解析器)
这里主要的对传过来的sql字符串进行解析,比如我们一开始接触的jdbc编程,就是将字符串类型的sql语句发送到mysql里,然后解析器首先对sql语句进行词法分析,形成语法树,接着再对语法树进行语法分析,看各个分词是否符合SQL92标准,符合的话再执行下一环节业务处理。
6.查询优化器(Optimizer)
查询优化器根据传过来的SQL语句,进行分析判断是否是最优的执行语句,主要针对一下三个方面进行分析:
* 使用哪一个索引(一个表有若干个索引,选择过滤力度最大的那个)
* 多表关联的表连接顺序
* WHERE条件的先后顺序(根据MYSQL最左前缀原则,会重新摆放条件顺序)
7.查询缓存(Cache&Buffer)
MYSQL会将每一条SQL进行hash处理后将hash值放到一个map中,每次有SQL来时先计算SQL的hash值,比较是否相同,相同的话可以执行内存的SQL,而不必对新的SQL语句进行解析、优化等操作,加快执行效率。
8.存储引擎(Pluggable Storage Engines)
MSQL的存储引擎支持可插拔特性,即用户可随意替换想用的存储引擎,也可以自定义自己的存储引擎,这里主要针对INNODB、MYISAM存储引擎进行分析比较。
平时涉及到存储引擎的选型,主要针对业务的需要来选择,可以参考各自的特点。
存储引擎的选型:
InnoDB:
支持事务处理,支持外键,支持崩溃修复能力和并发控制。如果需要对事务的完整性要求比较高(比如银行),要求实现并发控制(比如售票),那选择InnoDB有很大的优势。如果需要频繁的更新、删除操作的数据库,也可以选择InnoDB,因为支持事务的提交(commit)和回滚(rollback)。
MyISAM:
插入数据快,空间和内存使用比较低。如果表主要是用于插入新记录和读出记录,那么选择MyISAM能实现处理高效率。如果应用的完整性、并发性要求比 较低,也可以使用。
MEMORY:
所有的数据都在内存中,数据的处理速度快,但是安全性不高。如果需要很快的读写速度,对数据的安全性要求较低,不需要持久保存,可以选择MEMOEY。它对表的大小有要求,不能建立太大的表。所以,这类数据库只使用在相对较小的数据库表。
这里有一张MYSQL的简单执行流程图,凭靠这张图对MYSQL整体的一个执行流程会有清晰的认识。
MYSQL的逻辑架构就介绍到这里。当然MYSQL还有对应的物理架构,不过这一块主要涉及到MYSQL的各个日志文件,以及各个表的数据文件以及索引文件,在后面的章节再做介绍。
来源:https://www.cnblogs.com/process-h/p/13987069.html
猜你喜欢
- 原文地址:http://ilovetypography.com/2007/10/22/so-you-want-to-create-a-fon
- 一、pyinstaller简介Python是一个脚本语言,被解释器解释执行。它的发布方式:.py文件:对于开源项目或者源码没那么重要的,直接
- 本文实例为大家分享了python实现图书管理系统的具体代码,供大家参考,具体内容如下题目:写一个简单的图书借阅系统
- 一、 软件介绍 DB2MYSQL是一个可以自动将ACCESS数据库文件转化为对应的SQL代码的软件。可广泛应用于ACCESS数据库转换为MY
- 虎扑体育-NBA球员得分数据排行 第1页 示例代码:import requestsfrom lxml import etreeur
- For 循环可以遍历字符串,也可以遍历列表# for 循环# 语法特点:遍历操作,依次取集合容器中的几个值# for 临时变量
- 一、导入库import randomimport time二、注册用户我们用变量与input实现name = str(input('
- 本文为大家分享了python tkinter图形界面代码统计工具,供大家参考,具体内容如下#encoding=utf-8import os,
- 一、背景 简单的写个.exe程序,没必要去学习mfc、c++等,可以学习python。python可以轻易的调用windows的api,轻松
- 没办法,只能自己研究,经过大概一天时间吧,还是搞好了,写个总结。出现这种问题,解决方法大概有这几种:1.权限不够,导致弹出空吧提示框。(直接
- 从实时视频流中识别出人脸区域,从原理上看,其依然属于机器学习的领域之一,本质上与谷歌利用深度学习识别出猫没有什么区别。程序通过大量的人脸图片
- 前言:多线程简单理解就是:一个CPU,也就是单核,将时间切成一片一片的,CPU轮转着去处理一件一件的事情,到了规定的时间片就处理下一件事情。
- WordPress可以改造成twitter一样的微博网站,但是有一个坏处就是你要么用来做博客要么用来做微博,功能难兼得。相信大家在访问一些知
- 用鼠标创建小球,一个蹦来蹦去的解压小游戏…… 本次需要的外置包:pygame,pymu
- 如下所示:年月日时分秒>>> print datetime.datetime.now().strftime("%
- 函数原型pd.read_csv(filepath_or_buffer, sep=',', delimiter=None, h
- mysql 加了 skip-name-resolve不能链接的问题,要确认 MySql 是否采用过主机名的授权在 MySql Server
- 需求分析“员工刷脸考勤”系统,采用Python语言开发,可以通过摄像头添加员工面部信息,这里就涉及到两个具体的个问题,一个是应该以什么样的数
- PyQt中MainWindow, QWidget以及Dialog的区别和选择1. Qt界面分类在Qt Designer设计界面时,首先需要选
- 这篇文章主要介绍了python matplotlib饼状图参数及用法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考