MySQL 是怎样运行的:从根儿上理解 MySQL》笔记

时间:2024-03-30 08:46:17

首先,8折优惠码了解一下,比公众号的9折给力。

MySQL 是怎样运行的:从根儿上理解 MySQL》笔记

重新认识MySQL

  1. 前面主要是一些安装使用MySQL的过程,没必要记笔记
  2. 客户端与服务器连接过程,MySQL支持一下三种客户端进程与服务端进程通讯方式:
    1. TCP/IP
    2. 命名管道和共享内存(Windows操作系统中的两种进程间通信方式)
    3. Unix域套接字文件
  3. 服务器处理客户端请求过程
    1. 连接管理
      服务器进程会为每个连接进来的客户端分配一个线程,当客户端断开连接时候,不会马上销毁该线程,而是缓存起来,这样节省开销。线程分配过多会影响性能,所以可以限制同时连接到服务器的客户端数量。
    2. 解析与优化
      • 查询缓存
        • 命中缓存:一样的请求
        • 不命中
          • 两次请求有任何字符的不同,都不命中
          • 请求中包含系统函数,用户自定义变量与函数,一些系统表,比如使用now()函数
        • 缓存失效:缓存系统检测涉及到的每张表,只要表的结构或者数据修改,缓存就失效并删除。
      • 语法优化
        • 判断语法是否正确,将文本中要查询的表、各种查询条件提取出来放到MySQL服务器内部使用的一些数据结构上来。本质上是一个编译过程。
      • 查询优化
        • 优化查询效率,优化的结果就是生成一个执行计划。可以使用EXPLAIN语句查看执行计划。
    3. 存储引擎
      • 负责数据的存储和提取。
      • MySQL曾提供统一接口。
      • 常用InnoDBMyISAM
      • 查看支持的存储引擎。
        MySQL 是怎样运行的:从根儿上理解 MySQL》笔记
        • Transactions:是否支持事物
        • XA:是否支持分布式事务
        • Savepoints:是否支持部分事务回滚

启动选项和配置文件

  1. 可以通过启动选项或者配置文件设置
  2. 系统变量中的SESSIONGLOBAL
    • SET [GLOBAL|SESSION] 系统变量名 = 值;
    • SET [@@(GLOBAL|SESSION).]var_name = XXX;
    • GLOBAL:全局变量,影响服务器整体
    • SESSION:回话(local)变量,影响某个客户端的操作
    • 设置变量时候默认作用范围是SESSION,设置时候需要注意。
    • 有的系统变量没有作用范围,有的系统变量只读不可设置
  3. 状态变量
    • 显示程序运行状态,不可设置
    • GLOBALSESSION
    • SHOW [GLOBAL|SESSION] STATUS [LIKE 匹配的模式];
    • 同样默认是SESSION

字符集和比较规则

  1. 一种字符集可以有很多种规则

  2. 常用字符集

    • ASCII
    • ISO 8859-1latin1
    • GB2312
    • GBK
    • UTF-8
  3. MySQL支持的字符集和排序规则

    • utf8mb3:阉割版utf8,使用1-3个字节表示字符。
    • utf8mb4:正式版,使用1-4个字节表示字符。
    • 查看支持的字符集
      SHOW (CHARACTER SET|CHARSET) [LIKE 匹配的模式];
  4. 查看MySQL支持的比较规则
    SHOW COLLATION [LIKE 匹配的模式];

    • 比较规则的命名
      • 字符集_语言_后缀
      • 后缀的含义
        • _ai:不区分重音
        • _as:区分重音
        • _ci:不区分大小写
        • cs:区分大小写
        • _bin:以二进制比较
  5. 字符集和比较规则的应用

    1. MySQL有四个级别的字符集和比较规则
      • 服务器级别:
        • 查看:character_set_servercollation_server
        • 配置:启动时,配置文件或者启动项设置character_set_server=gbk collation_server=gbk_chinese_ci两个变量。运行时通过set语句修改以上两个变量的值来修改。
      • 数据库级别:
        • 查看:character_set_databasecollation_database,注意这两个变量是只读的。
        • 配置:建库时候配置,若未配置使用服务器级别的。也可以使用ALTER DATABASE语句修改。
      • 表级别
        - 查看:查看建表语句。
        - 配置:建表时候设置,若未设置使用数据库级别默认的。已存在的表通过ALTER TABLE语句修改。
    • 列级别
      • 查看:查看建表语句。
      • 配置:建表时未配置使用表默认的。存在的使用ALTER TABLE table_name MODIFY column ...语句修改。
    1. 只修改字符集,比较规则变为字符集默认的。
      只修改比较规则,字符集变成比较规则对应的。
  6. 客户端和服务器通信的字符集

    1. MySQL中字符集的转换
      • 转换过程中使用的3个系统变量
        • character_set_client服务器解码请求时使用的字符集,服务器会认为客户端发送过来的请求是此变量对应的字符集编码的,若不是则会出错。
        • character_set_connection 服务器处理请求时会把请求字符串从character_set_client转为character_set_connection
        • character_set_results 服务器向客户端返回数据时使用的字符集,客户端需要使用这个字符集来解码。
    2. SET NAMES 字符集名,可以将以上三个系统变量设置为同一个值。

InnoDB记录存储结构