MySQL分层和查询数据的流程
MySQL分层
MySQL分层
主要分为:连接层,服务层,引擎层,存储层
客户端执行一条select命令的流程如下

连接器
功能:
负责跟客户端建立连接、获取权限、维持和管理连接
细节:
1.当用户登录成功后,用户就会拿到权限信息,即使管理员更改了你的权限,但是在本次连接中你的权限依然不变
2.连接分,长连接、短连接,连接对象比较消耗内存,要注意连接的管理
报错:
mysql -u -p
这里就会返回账号密码错误
查询缓存
功能:
当连接建立完成后,如果执行查询语句,第二步就会执行查询缓存,如果缓存内有之前的查询结果,那么直接命中返回结果,效率会很高。
缺点(不推荐使用,利大于弊):
查询缓存很容易失效,如果一张表进行了一个更新,那么这张表所有的缓存会被清空。
注意:
MYSQL8.0直接把查询缓存这块给删除了
分析器
功能:
如果查询缓存没有命中,就会进入分析器,进行词法分析和语法分析,会分析表是否存在,字段是否存在等等
报错:
我们一般接触的最多的错误就是从这部分返回的
优化器
功能:
优化器是在表里面有多个索引的时候,决定使用哪个索引;或者在一个语句有多个多表查询的时候,会进行决定,用哪个索引,或者先查询哪个表。
虽然不管怎么查询,最后的结果都是一样的,但是不同的查询方式会有不同的查询效率
有时候觉得你写的sql语句太复杂了,性能太低了,mysql帮你的优化sql语句,提高效率(因为是帮你优化改写了你查询的sql,可能会出现一些问题)
执行器:
作用:
既然知道要查询什么,怎么查询了,那么就到了执行器执行的时候了,到这一步会检查你的权限,是否有权限操作相关的表,如果有权限,就打开表,然后根据表的引擎定义,去使用引擎的接口
报错:
如果在查询缓存就命中数据,但是没有权限,则权限错误在查询缓存就会出现,否则,就会在执行器,报出没有权限的错误
引擎:
图中有很多引擎,是因为MySQL有很多的引擎
select * from zx where id=125
执行流程:
(没有索引的表)
执行器调用InnoDB引擎接口取取zx表的第一行,然后判断id是否为125,如果满足条件就返回给结果集,如果不满足就继续拿下一条的数据重复操作,直到遍历了所有数据,最后把结果集返回给客户端
有索引的表,逻辑是差不多的,但是细节有差别
InnoDB和MyISAM区别
InnoDB(默认):事务优先(适合高并发:行锁)
MyISAM:性能优先(表锁)
MySQL分层和查询数据的流程的更多相关文章
- MySql数据库,查询数据导出时会出现重复的记录(数据越多越明显)
在查询数据时,数据量多的时候,我们会使用分页功能. 每页显示多少数据. 这种情况下,一半看不出什么问题. 而导出数据时,有时就是通过分页的方法,逐步讲数据追加到导出文件中. 当全部数据都导出之后,就有 ...
- php 基本连接mysql数据库和查询数据
连接数据库,有三种方法 1. 常规方式: $con=mysql_connect($dbhostip,$username,$userpassword) or die("Unable to co ...
- IntelliJ IDEA2017 java连接mysql数据库并查询数据
最近自己开始重新学习java基础了,做java开发不可避免要处理数据库,由于好久不写java了,对idea也有点陌生了.所以这里写篇用jdbc来连接mysql的文章 至于mysql怎么装,请自行百度 ...
- MySQL下分页查询数据
-- 分页 -- 前两条 -- 启始位置从下标0开始,查询的是数据库中的第1条开始 -- 0:启始位置 2:一次性查询多少条 select * from account LIMIT 0,2; -- ...
- java实现连接mysql数据库单元测试查询数据项目分享
1.按照javaweb项目的要求逐步建立搭建起机构,具体的类包有:model .db.dao.test;具体的架构详见下图: 2.根据搭建的项目架构新建数据库test和数据库表t_userinfo并且 ...
- MySQL 查询数据
MySQL 查询数据 MySQL 数据库使用SQL SELECT语句来查询数据. 你可以通过 mysql> 命令提示窗口中在数据库中查询数据,或者通过PHP脚本来查询数据. 语法 以下为在MyS ...
- 十二、MySQL 查询数据
MySQL 查询数据 MySQL 数据库使用SQL SELECT语句来查询数据. 你可以通过 mysql> 命令提示窗口中在数据库中查询数据,或者通过PHP脚本来查询数据. 语法 以下为在MyS ...
- php MySQL 查询数据
以下为在MySQL数据库中查询数据通用的 SELECT 语法: SELECT column_name,column_name FROM table_name [WHERE Clause] [LIMIT ...
- 吴裕雄--天生自然MySQL学习笔记:MySQL 查询数据
MySQL 数据库使用SQL SELECT语句来查询数据. 可以通过 mysql> 命令提示窗口中在数据库中查询数据,或者通过PHP脚本来查询数据. 语法 以下为在MySQL数据库中查询数据通用 ...
随机推荐
- const var let 三者的区别
1.const定义的变量不可以修改,而且必须初始化. ;//正确 const b;//错误,必须初始化 console.log('函数外const定义b:' + b);//有输出值 b = ; con ...
- 2019 年容器生态统计报告发布 | 云原生生态周报 Vol. 26
作者 | 酒祝.天元.元毅.心水.衷源 业界要闻 1.2019 年容器生态统计报告发布 据报告显示,Kubernetes 占据 77% 的容器编排产品份额,Docker 占据 79% 的容器引擎产品 ...
- 子树问题(DP)
这题显然是DP 首先,\(dp[i][j]\)表示树深度小于等于i,树的大小为j的有根树的数量$ 可以循环枚举根节点编号次大的子树的大小k. \(dp[i][j]=\sum^{j-1}_{k=1}dp ...
- [2018-10-29] python开发个人资源共享网--第二天
创建Django目录 startproject my_project 创建APP startapp my_app 手动创建的文件夹 log 日志 media 用户上传下载 static 静态文件 配置 ...
- LVS 十种算法
LVS虚拟服务器是章文嵩在国防科技大学就读博士期间创建的,LVS可以实现高可用的.可伸缩的网络服务. LVS集群组成: 前端:负载均衡层 (一台或多台负责调度器构成) 中间:服务器群组层 (由一组 ...
- spring session源码解析
模块划分 core部分代码 存储实现部分部分: jdbc实现 具体存储的实现类 例如:org.springframework.session.jdbc.JdbcOperationsSessionRep ...
- Ubuntu13.10编译android源码中遇到的问题
1. jdk的版本不对 我开始安装的是最新的jdk7,但是编译时会出现jdk的版本
- NOI导刊总结
NOI导刊总结 前两天去郑州,参加了什么NOI导刊的培训,然后就发现大佬是真的多,还十分意外的发现了一个事,清华北大是不是发笔记本和耳机,为啥三个老师的都一模一样... 这几天主要以讲.NOIP知识点 ...
- day1-python初识以及变量
一.变量:将输入的内容赋值给变量,即变量=输入的内容 n1=input('请输入用户名:') 二. 变量名可以是 -英文. -数字.数字不能开头 -下划线,但是不可以下划线开头 不能是关键字 'and ...
- java本地缓存
1.为什么要使用缓存 由于服务器.数据库.网络等资源有限,无法支撑越来越多的请求与计算量,所以将一部分数据放在缓存中,以此减小薄弱环节的计算量和请求流程. 网站中缓存的应用场景: 1:可 ...