资讯详情

MySQL逻辑分层介绍

上一篇文章主要介绍了MySQL在Ubuntu18.04系统的安装,以及安装过程中可能遇到的一些问题的解决方案。

本文开始介绍MySQL数据库的逻辑分层。通过本文的介绍,我们可以大致MySQL从客户端发出请求后,服务器经历了什么样的过程。帮助后面MySQL加深对优化的理解。

MySQL逻辑分层

一般来说,MySQL逻辑可分为连接层、服务层、引擎层、存储层四个层次 。

连接层

提供连接到客户端的服务。

当客户端发出请求时(如增删和修改)SQL语句),首先到达层,将服务器连接到客户端。

服务层

服务层分为两个功能:

为用户提供各种接口。 如select、insert等

提供SQL优化器(MySQL Query Optimizer)。 SQL优化器是MySQL服务层自带的服务会自动优化用户写得不是最好的SQL,使其达到优化效果。但由于优化器毕竟只是优化器,有时会更改用户定制的优化方案,使用户自己的优化方案无效,需要注意。

引擎层

引擎层提供各种数据存储方法。MySQL有很多存储引擎,比如更常用InnoDB, MyISAM。

InnoDB与MyISAM的区别为:

InnoDB 事务优先,适合高并发操作,采用行

MyISAM 性能优先,适合查询多个场景,使用表锁

查询数据库支持哪些引擎?SQL:

mysql> show engines;

-------------------- --------- ---------------------------------------------------------------- -------------- ------ ------------

| Engine | Support | Comment | Transactions | XA | Savepoints |

-------------------- --------- ---------------------------------------------------------------- -------------- ------ ------------

| InnoDB | DEFAULT | Supports transactions, row-level locking, and foreign keys | YES | YES | YES |

| MRG_MYISAM | YES | Collection of identical MyISAM tables | NO | NO | NO |

| MEMORY | YES | Hash based, stored in memory, useful for temporary tables | NO | NO | NO |

| BLACKHOLE | YES | /dev/null storage engine (anything you write to it disappears) | NO | NO | NO |

| MyISAM | YES | MyISAM storage engine | NO | NO | NO |

| CSV | YES | CSV storage engine | NO | NO | NO |

| ARCHIVE | YES | Archive storage engine | NO | NO | NO |

| PERFORMANCE_SCHEMA | YES | Performance Schema | NO | NO | NO |

| FEDERATED | NO | Federated MySQL storage engine | NULL | NULL | NULL |

-------------------- --------- ---------------------------------------------------------------- -------------- ------ ------------

9 rows in set (0.00 sec)

从以上结果可以看出,MySQL5.7默认引擎是InnoDB(DEFAULT),除了FEDERATED支持所有其他发动机。

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

mysql> show variables like '%storage_engine%';

---------------------------------- --------

| Variable_name | Value |

---------------------------------- --------

| default_storage_engine | InnoDB |

| default_tmp_storage_engine | InnoDB |

| disabled_storage_engines | |

| internal_tmp_disk_storage_engine | InnoDB |

---------------------------------- --------

4 rows in set (0.00 sec)

指定数据库对象的引擎:

一般指定哪个引擎用于某个表,因为MySQL所有的表都要靠database,所以在此之前,先创造一个database,如:

mysql> create database testDB;

Query OK, 1 row affected (0.00 sec)

mysql> show databases;

--------------------

| Database |

--------------------

| information_schema |

| mysql |

| performance_schema |

| sys |

| testDB |

--------------------

5 rows in set (0.00 sec)

如上所述,成功创建了一个名称testDB下一系列文章的所有演示都在数据库中testDB中进行。

下面,就在testDB创建一个名字tbl_A表中有三个字段,分别是id(int 型、自增、主键),name(varchar型,长度为20),descript(varchar类型,长度为80)。指定的存储引擎是MyISAM。

mysql> use testDB;

Database changed

mysql> create table tbl_A(

-> id int(4) auto_increment,

-> name varchar(20),

-> descript varchar(80),

-> primary key(id)

-> )ENGINE=MyISAM;

Query OK, 0 rows affected (0.04 sec)

如上所示,MyISAM建成了引擎表。

存储层

存储层中存储最终数据。

配置在终端直接操作MySQL

每次操作数据库时,我们都必须完成以下步骤,首先使用它mysql -uroot -p登录到客户端,然后指定数据库,然后在数据库中操作表,更麻烦,因此,可以定义一个别名,完成上述操作,在后续操作中,直接使用终端操作的别名,不需要每次进入MySQL客户端。

例如,我们将该别名定义为isql_s,直接跟上命令SQL可操作语句。配置方法如下:

先使用vim编辑器打开~/.bashrc,然后在下面加以下句子:

alias isql_s='mysql -uroot -pcyc2010 -P3306 -DtestDB --auto-rehash -A -e'

上述命令的意思是定义一个名称isql_s替换别名mysql -uroot -pcyc2010 -P3306 -DtestDB --auto-rehash -A -e命令。

该命令指定mysql用户为root;

-p后面跟的是root用户密码;

-P后面是口号,如果是本地,默认为3306;(注意大小写和密码的区别)

-D后面是database我在这里指定的名字testDB;

--auto-rehash是自动补充,这个加不加都无所谓;

-A这意味着不预读数据库信息,因为当数据库中有特别多的表时,预读数据库信息会使打开数据库特别慢。有了这个参数,打开效率可以提高。

-e后面可以直接跟代表SQL语句。

如下图120行所示:

9d10f603924a54119deb6d149bebd921.png

配置完成后,按:wq!命令退出编辑器,然后使用如下命令,使配置参数生效:

$ . ~/.bashrc

接下来,就可以演示一下,如何使用isql_s命令直接访问数据库了。比如我要查本文建的表tbl_A的表结构:

chenyc@DESKTOP-Q5J25HR:~$ isql_s "desc tbl_A"

mysql: [Warning] Using a password on the command line interface can be insecure.

+----------+-------------+------+-----+---------+----------------+

| Field | Type | Null | Key | Default | Extra |

+----------+-------------+------+-----+---------+----------------+

| id | int(4) | NO | PRI | NULL | auto_increment |

| name | varchar(20) | YES | | NULL | |

| descript | varchar(80) | YES | | NULL | |

+----------+-------------+------+-----+---------+----------------+

可以看到,直接就能查询出来,而不需要重新进入数据库,指定database等一系列繁琐的操作。

使用以上命令时,可以看到一句Warning,该警告信息是说在命令行直接输入密码是不安全的,这个并不影响查询结果,可以不用管它。

标签: j25系列连接器

锐单商城拥有海量元器件数据手册IC替代型号,打造 电子元器件IC百科大全!

锐单商城 - 一站式电子元器件采购平台