Mysql简短又易懂

MySql

连接池:的两个参数

最大连接数:可以同时发起的最大连接数

单次最大数据报文:接受数据报文的最大长度

数据库如何存储数据

存储引擎:

InnoDB:通过执行器对内存和磁盘的数据进行写入和读出

  1. 优化SQL语句
  2. innoDB会把需要写入或者更新的数据写入Bu方法二POOL中
  3. 程序员通过执行器连接BufferPool 同时将之前的数据记录到Undo Log日志文件中
  4. 线程将需要更新写入的数据读出后写入磁盘 这个过程通过 OPean+write函数构成
  5. 为了防止突然断电数据丢失 在读入数据时会象Redo Log Buffer中写入一份相同的数据。然后再将其刷到磁盘中
  6. 写入成功后BingLog会向RedoLog告知写入完毕的事

3 Mysal如何保管数据

数据在数据库中以磁盘和内存两种形式存在

磁盘:建表后innoDB会在磁盘的目录下创建于这个表对应的两个文件t.frm(存储表结构) t.ibd(表空间:用来存储数据和索引)表中的最小单位是页这也是与磁盘交互的最小单位,页大小 16kb

4 MySql如何查询数据

  1. 客户端通过连接驱动和连接池连接,客户端向连接池发送一个单独的数据包,同时传输数据包的大小是有上限的
  2. 接受到sql后在查询缓存的地方查找(8.0后被删除)
  3. 查询缓存中没有就通过sql解析器来解析sql语句
  4. 解析后的sql会被提交给预处理器,优化器优化 优化后sql就会变成呢一个可以执行的执行计划
  5. 执行器 根据执行计划 在Handler API中查找相应的API,同时进行组合和调用达成执行计划(优化器会通过Handle实例来获取表和列等信息),调用Api来拿到返回结果。

数据页

结构:页头页尾 数据行

数据行:会直接与表中的数据行相对应

相关推荐
陌上丨3 小时前
Redis的Key和Value的设计原则有哪些?
数据库·redis·缓存
AI_56783 小时前
AWS EC2新手入门:6步带你从零启动实例
大数据·数据库·人工智能·机器学习·aws
ccecw3 小时前
Mysql ONLY_FULL_GROUP_BY模式详解、group by非查询字段报错
数据库·mysql
JH30733 小时前
达梦数据库与MySQL的核心差异解析:从特性到实践
数据库·mysql
数据知道4 小时前
PostgreSQL 核心原理:如何利用多核 CPU 加速大数据量扫描(并行查询)
数据库·postgresql
麦聪聊数据5 小时前
Web 原生架构如何重塑企业级数据库协作流?
数据库·sql·低代码·架构
未来之窗软件服务5 小时前
数据库优化提速(四)新加坡房产系统开发数据库表结构—仙盟创梦IDE
数据库·数据库优化·计算机软考
Goat恶霸詹姆斯6 小时前
mysql常用语句
数据库·mysql·oracle
大模型玩家七七7 小时前
梯度累积真的省显存吗?它换走的是什么成本
java·javascript·数据库·人工智能·深度学习
曾经的三心草7 小时前
redis-9-哨兵
数据库·redis·bootstrap