博客
关于我
MySQL复习day09:逻辑架构和引擎,索引详解(explain)
阅读量:580 次
发布时间:2019-03-10

本文共 976 字,大约阅读时间需要 3 分钟。

Linux下的MySQL启停及MySQL逻辑架构

启动与停止

启动MySQL:

service mysqld start

停止MySQL:

service mysqld stop

MySQL逻辑架构

MySQL采用三层架构:连接层 → 服务层 → 存储引擎层

  • 连接层

    • 完成客户端与服务器的连接,如sock通信或基于//.socket的通信。
    • 提供线程池支持,为用户登录分配线程。
    • 支持SSL安全连接。
  • 服务层

    • 提供核心SQL接口及相关功能,如查询优化和缓存。
    • 解析并建立内部查询树,优化查询执行。
  • 存储引擎层

    • 数据存储和提取,通过API与存储引擎通信。
    • 支持多种存储引擎,如 InnoDBMyISAM

  • MySQL引擎对比

    MyISAM vs InnoDB

    对比项 MyISAM InnoDB
    主外键 不支持 支持
    事务支持 不支持 支持
    行锁模式 表锁(锁整个表) 行锁(锁单行)
    缓存 索引缓存,不存储真实数据 索引和真实数据都缓存
    表空间大小 较小 较大
    默认安装
    常用场景 线性表优化 事务支持、复杂查询

    索引设计原则

  • 自动唯一索引:主键自动创建唯一索引。
  • 高频查询字段:对经常查询的字段创建索引。
  • 外键关联:外键字段建议创建索引。
  • 频繁更新字段:避免索引,减少更新开销。
  • 查询不使用的字段:不创建索引。
  • 索引选择性:用户查询多于数据分布时,建议建立组合索引。
  • 排序字段:涉及排序的字段宜建立索引。

  • 常见索引误区

    不适合索引的情况

    • 数据重复或分布不均:建立索引无效。
    • 经常增删改的表:索引会降低更新效率。
    • 表记录过少:索引对硬盘占用过多。

    查询优化与分析

    MySQL优化器通过访问计划生成优化策略:

  • 优化器模块:分析和优化SELECT语句。
  • 查询分类:区分简单查询、联合查询等。
  • 统计信息采集:分析表结构及索引用于生成最优执行计划。
  • 常见性能问题

    • CPU瓶颈:内存充足,数据装入速度受限。
    • IO瓶颈:磁盘读入速度成为限制。
    • 连接缓存:优化数据库连接池设置。

    常用Join类型

    • 左外连接:保留左边表的所有记录。
    • 右外连接:保留右边表的所有记录。
    • 内连接:保留两个表的交集。
    • 全外连接:保留左边表减去交集。
    • 联合索引优化:确保联合索引用于减少IO开销。

    总结

    了解MySQL的架构、索引原则及性能优化,能够有效提升数据库性能。

    转载地址:http://pdcvz.baihongyu.com/

    你可能感兴趣的文章
    MySQL报Got an error reading communication packets错
    查看>>
    Mysql报错Can‘t create/write to file ‘/tmp/#sql_3a8_0.MYD‘ (Errcode: 28 - No space left on device)
    查看>>
    MySql报错Deadlock found when trying to get lock; try restarting transaction 的问题解决
    查看>>
    MySQL报错ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘
    查看>>
    Mysql报错Packet for query is too large问题解决
    查看>>
    mysql报错级别_更改MySQL日志错误级别记录非法登陆(Access denied)
    查看>>
    Mysql报错:too many connections
    查看>>
    MySQL报错:无法启动MySQL服务
    查看>>
    mysql授权用户,创建用户名密码,授权单个数据库,授权多个数据库
    查看>>
    mysql排序查询
    查看>>
    MySQL排序的艺术:你真的懂 Order By吗?
    查看>>
    MySQL排序的艺术:你真的懂 Order By吗?
    查看>>
    Mysql推荐书籍
    查看>>
    Mysql插入数据从指定选项中随机选择、插入时间从指定范围随机生成、Navicat使用存储过程模拟插入测试数据
    查看>>
    MYSQL搜索引擎
    查看>>
    mysql操作数据表的命令_MySQL数据表操作命令
    查看>>
    mysql操作日志记录查询_如何使用SpringBoot AOP 记录操作日志、异常日志?
    查看>>
    MySQL支持的事务隔离级别,以及悲观锁和乐观锁的原理和应用场景?
    查看>>
    mysql支持表情
    查看>>
    MySQL支撑百万级流量高并发的网站部署详解
    查看>>