Mysql数据库属于关系型数据库(mysql、oracle、sql server),非关系型数据库有DB2、Redis

MySQL执行原理,逻辑分层、更改数据库处理引擎

作者:Stanley 罗昊

【转载请注明出处和署名,谢谢!】

用了那么长时间的MySQL,sql语句相信早已烂熟于心,于是,我就试着去了解它的执行原理,以下是我学习过程中的总结要点。

只要是B/S架构,都是会有客户端与服务端,mysql也不例外。

首先客户端发出一个请求,这个请求就是一个查询请求(Select),而它请求的对象就是服务端,服务端是怎么处理这项查询功能的呢?

逻辑分层

首先可以把服务端想象成一个大的容器,里面有四层结构,当一个请求过来后,将会执行这四层,执行一遍后才会返回给我们想要的结果。

第一层:连接层

也就是说,我们客户端发送一个Select是直接交给连接层来处理,而它的作用就是提供与客户端连接的服务

连接层只是与客户端建立起连接,并且拿到我们的请求(Select),但是它本身不做处理,因为它只做连接,那谁来处理呢?接着往下走。

第二层:服务层

服务层可以干两件事情:

1.提供给用户各种可以使用的接口

比如说刚才的查询就是,我们常见的CRUD(增删改查)操作都在这里,连接层拿到这个Select直接了给了服务层,这里除了给用户提供接口以外,还提供了一个声称为Sql优化器的东西

2.Sql优化器(MySQL QUery Optimier)

当我们编写Sql语句执行时,执行到这里后(第二层),优化器会觉得我写的sql语句性能不够好,这个时候,优化器会自己写一个等价于跟我写的执行后结果一致的sql语句进行代替,这个等价写法就是通过这个优化器把你写的sql给优化了,因为它觉得你写的性能太低了,所以它就把你写的sql给优化了一下,这个优化操作就是优化器干的事情;

很明显,优化器可以将sql语句进行优化,它是可以对性能产生一定的好处,但是有弊端!举个例子:

"当你自己优化时是a,但是实际执行并不是a,因为优化器会觉得你优化的还是不够好,结果把a变成b了,也就说,我明明写的是a,但程序执行的是b"

这会对我们开发过程造成混乱,因为它已经被优化了。你写的跟之前的已经不是一致的了

第三层:引擎层

它提供了各种存储数据的方式,常见的有:lnnoDB、MylSAM

重点区别:

lnnoDB 【Mysql默认】:它在设计的时候,它是事物优先 【适合高并发操作】原理:因为它是行锁,我每一条数据都要锁,锁的太多,性能就降低了,虽然性能降低了,但是我适合高并发了,就不容易出错了

MylSAM:性能优先原理:因为它是表锁,对于表里面的十条数据来说是不受影响的,对十条锁一次就完了,所以性能快

性能优先就很好理解了,比如说一万条数据,它处理的快一点,效率会高一点

事物就是防止一些并发操作,并发太大可能出错,所以适合高并发操作

所以在做项目的时候,建立数据库时,如果性能优先,就选择MylSAM引擎,如果是高并发操作,就选择lnnoDB 引擎;如何更换引擎我下面会讲

第四层:存储层

这就很好理解了,最终的数据在存储层里面存储

说完四层后,我们来厘清思路

首先客户端发出一个Select操作--->连接层接收后给服务层--->服务层对你的查询进行一个优化,并把优化结果给引擎层--->选择当前数据库的引擎,选完引擎后,引擎将最终的数据交给了存储层--->存储层,用存储层来存数据

查看引擎

show engines;查看Mysql所支持的所有引擎

执行结果:

yes就是支持,在InnoDB支持选项是DEFAULT(默认)也就说明,当我们创建数据库的时候默认引擎就是InnoDB

查看当前数据库使用的引擎

show variables like '%storage_engine%';

执行结果:

很显然,我们目前用的就是InnoDB

指定数据库对象的引擎

我现在创建一张表,这个张表我不用InnoDB,用MylSAM,因为我想让它性能优先,下面我就使用mysql命令行进行创建表

1.指定数据库指令:use 数据库名

2.在指定的数据库中创建一张简单的表

create table tb(

id int (4),

name varchar(5),

primary key(id)

)ENGINE=MyISAM;

执行结果:

表明创建成功,并且该表的引擎是指定的我们手动指定的引擎,而不是默认的。

Mysql数据库 day1的更多相关文章

  1. html页面通过http访问mysql数据库中的内容,实现用户登录的功能

    需求: 通过html编写用户登录页面,页面内容包括用户名.密码和登录按钮,点击登录后访问login.php文件,使用按钮默认的submit提交用户名和密码,在login.php中访问mysql数据库, ...

  2. 超哥mysql数据库部分blog整理:

    总目录:mysql数据库阶段学习目录 https://www.cnblogs.com/clschao/articles/10065275.html Day1. 1.数据库初识 https://www. ...

  3. MySQL数据库使用xtrabackup备份实现小例子

    关于MySQL数据库的备份的工具和方式也比较多,本文只简单介绍一些我司一个平台的备份方案.Xtrabackup是由percona开源的免费数据库热备份软件,但是只能对InnoDB数据库和XtraDB存 ...

  4. nodejs进阶(6)—连接MySQL数据库

    1. 建库连库 连接MySQL数据库需要安装支持 npm install mysql 我们需要提前安装按mysql sever端 建一个数据库mydb1 mysql> CREATE DATABA ...

  5. 当忘记mysql数据库密码时如何进行修改

    因为长时间没有使用数据库了,或者把密码改完之后就忘了数据库密码,不能正常进入数据库,也无法修改密码,有一个简单的常用修改密码方式: 1.首先找到和打开mysql.exe和mysqld.exe所在的文件 ...

  6. MySQL数据库和InnoDB存储引擎文件

    参数文件 当MySQL示例启动时,数据库会先去读一个配置参数文件,用来寻找数据库的各种文件所在位置以及指定某些初始化参数,这些参数通常定义了某种内存结构有多大等.在默认情况下,MySQL实例会按照一定 ...

  7. 一起学微软Power BI系列-使用技巧(1)连接Oracle与Mysql数据库

    说起Oracle数据库,以前没用过Oracle不知道,但是这1年用Oracle后,发现真的是想狂吐槽,特别是那个.NET驱动和链接字符串,特别奇葩.总归是和其他数据库不一样,标新立异,不知道为何.另外 ...

  8. CentOS下mysql数据库常用命令总结

    mysql数据库使用总结 本文主要记录一些mysql日常使用的命令,供以后查询. 1.更改root密码 mysqladmin -uroot password 'yourpassword' 2.远程登陆 ...

  9. [原创]java使用JDBC向MySQL数据库批次插入10W条数据测试效率

    使用JDBC连接MySQL数据库进行数据插入的时候,特别是大批量数据连续插入(100000),如何提高效率呢?在JDBC编程接口中Statement 有两个方法特别值得注意:通过使用addBatch( ...

随机推荐

  1. sql 字符、数字类型自动转换及运算

    本页面所有内容也可以在oracle 运行,只需要把int.float .decimal 改为 number类型即可 -- 字符串转数字 int 类型 drop table test;create ta ...

  2. 最常见到的runtime exception 异常

    ArithmeticException, 算术异常ArrayStoreException, 将数组类型不兼容的值赋值给数组元素时抛出的异常BufferOverflowException, 缓冲区溢出异 ...

  3. Entity Framework 6.X实现记录执行的SQL功能

    Entity Framework在使用时,很多时间操纵的是Model,并没有写sql语句,有时候为了调试或优化等,又需要追踪Entity framework自动生成的sql(最好还能记录起来,方便出错 ...

  4. 常用CSS技术收藏

    常用CSS技术收藏 必须要掌握的技术 盒子模型 定位模型 定位模型 css sprite(雪碧/css精灵)相关 css sprite 坐标定位为何为负以及定位方法 布局 圣杯布局小结 规范 BEM ...

  5. [翻译] M13ProgressSuite

    M13ProgressSuite https://github.com/Marxon13/M13ProgressSuite A set of classes used to display progr ...

  6. [翻译] DDExpandableButton

    DDExpandableButton https://github.com/ddebin/DDExpandableButton Purpose - 目的 DDExpandableButton is a ...

  7. 使用CAReplicatorLayer [1]

    使用CAReplicatorLayer [1] 说明 https://developer.apple.com/library/ios/documentation/GraphicsImaging/Ref ...

  8. QT的时区转换以及使用注意事项

    QDateTime localDate = QDateTime::fromString("2018-12-11 10:40:00", "yyyy-MM-dd hh:mm: ...

  9. 长距离单历元非差GNSS网络RTK理论与方法总结(未完)

    2018-11-04 1.状态空间: 状态空间是控制工程中的一个名词.状态是指在系统中可决定系统状态.最小数目变量的有序集合.   而所谓状态空间则是指该系统全部可能状态的集合.简单来说,状态空间可以 ...

  10. 10-19文献阅读之DCB

    ---恢复内容开始--- <一种精确估计区域北斗接收机硬件延迟的方法>-2016-,很有价值 估计北斗接收机硬件延迟,不需要传统复杂的电离层模型.已知一个参考站接收机硬件延迟的条件下,利用 ...