Mysql数据目录(3)---表数据结构myISAM(二十六)

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: Mysql数据目录(3)---表数据结构myISAM(二十六)

前面说了innoDB表在mysql5.6.6之前存储在系统空间,5.6.6之后存储在独立的空间,表结构存储在.frm文件,里面记录着字符集,行规则等,表数据存储在.ibd里面,里面存储着数据和索引。

Mysql数据目录(2)---表数据结构(二十五)


myISAM表存储数据


myISAM表不同的是,上面说的innoDB因为聚簇索引b+树节点是索引即数据,数据即索引,索引和数据是存在同一个文件的.ibd。但myISAM数据存放在 数据文件,索引存放在索引文件,当我们在指定数据库建立myISAM表时,会有三个文件:test.frm,test.MYD,test.MYI。其中test.MYD是数据文件,.MYI是索引存放索引的索引文件。


视图在文件中的表示


我们都指定,视图其实是虚拟的表,查询的是指定表的本身,索引视图并没有真实的数据,只需要存储视图的结构,如果创建视图 ,则会生成一个视图名.frm的文件。


其他文件


除了上述说的文件外,数据库还存着为了mysql能高效运行的额外文件,主要包括:

服务器进程文件:我们知道,每运行一个mysql服务器,都意味着启动一个进程,mysql会吧进程id写入一个特定的文件。


服务器日志文件:在服务器运行时候,会产生各种各样的日志,比如查询日志,错误日志,二进制日志,redo日志等,这些日志会有各种用途,以后的文章会详细说明。

默认生成SSL和RSA证书和秘钥文件:主要是为了客户端和服务端安全通信生成的一些文件。


文件系统对数据库的影响(注意事项)


因为mysql生成的数据库,表等取的名字,会在文件系统中自动生成同名的目录级或者文件,导致文件系统的一些限制就会出现:

1)、数据库和表名称不能超过文件系统允许的最大长度:因为文件名称和目录名称在文件系统上都会有限制,那取同名的mysql名称时候,肯定会被限制长度。

2)、特殊字符问题:mysql会自动除数字和拉丁字母外的所有字符在文件名称转成编码值来取文件名,比如‘test?’取同名的文件名因为?不属于数字和拉丁字母,.frm文件就是 test@003f.frm。

3)、文件大小受限系统文件大小:与文件名称同理,表数据里存储的大小,不可能超过文件系统限制的文件大小,所以还是会被受限制。


MYSQL数据库系统的简介


前面我们说了mysql有好几个数据库,这些数据库包含了mysql服务器运行过程所需要的一些运行状态信息。


Mysql:非常核心的数据库,存储着mysql用户账号和权限信息,一些存储过程,事件定义的信息,一些运行过程中产生的日志信息,一些帮助信息时区信息。


Information_schema:这个数据库保留着mysql服务器维护所有其他数据库信息,比如哪些表,哪些视图,哪些触发器,哪些列,哪些索引等。这些并不是真实的用户信息,是一些描述信息,有时候也称为元数据。


Performance_schema:主要保存着mysql服务器运行过程中的状态信息,算是对mysql性能监测。比如最近执行哪些sql,查询时间耗费多少,内存使用情况等。


Sys:主要通过视图的方式吧information_schema和performance_schema结合起来,让我们更容易了解性能信息。

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
6天前
|
存储 缓存 关系型数据库
【赵渝强老师】MySQL的MyISAM存储引擎
在MySQL5.1版本之前,默认存储引擎为MyISAM。MyISAM管理非事务表,提供高速存储和检索,支持全文搜索。其特点包括不支持事务、表级锁定、读写互阻、仅缓存索引等。适用于读多、写少且对一致性要求不高的场景。示例代码展示了MyISAM存储引擎的基本操作。
|
5月前
|
关系型数据库 MySQL 数据库
数据迁移脚本优化过程:从 MySQL 到 Django 模型表
在大规模的数据迁移过程中,性能问题往往是开发者面临的主要挑战之一。本文将分析一个数据迁移脚本的优化过程,展示如何从 MySQL 数据库迁移数据到 Django 模型表,并探讨优化前后的性能差异。
|
5月前
|
分布式计算 DataWorks MaxCompute
DataWorks产品使用合集之需要将mysql 表(有longtext类型字段) 迁移到odps,但odps好像没有对应的类型支持,该怎么办
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
|
1月前
|
存储 缓存 关系型数据库
详细解析MySQL中的innodb和myisam
总之,InnoDB和MyISAM各有千秋,选择合适的存储引擎应基于对应用程序特性的深入理解,以及对性能、数据完整性和可扩展性的综合考量。随着技术发展,InnoDB因其全面的功能和日益优化的性能,逐渐成为更广泛场景下的首选。然而,在特定条件下,MyISAM依然保留其独特的价值。
112 0
|
4月前
|
存储 SQL 关系型数据库
(十三)MySQL引擎篇:半道出家的InnoDB为何能替换官方的MyISAM?
MySQL是一款支持拔插式引擎的数据库,在开发过程中你可以根据业务特性,从支持的诸多引擎中选择一款适合的,例如MyISAM、InnoDB、Merge、Memory(HEAP)、BDB(BerkeleyDB)、Example、Federated、Archive、CSV、Blackhole.....
|
5月前
|
存储 关系型数据库 MySQL
关系型数据库MySQL的MyISAM
【6月更文挑战第17天】
55 11
|
5月前
|
存储 关系型数据库 MySQL
|
4月前
|
存储 SQL 关系型数据库
MySQL设计规约问题之在数据库设计中,为什么要适当考虑反范式的表设计
MySQL设计规约问题之在数据库设计中,为什么要适当考虑反范式的表设计
|
4月前
|
SQL 存储 数据库
MySQL设计规约问题之如何处理日志类型的表
MySQL设计规约问题之如何处理日志类型的表
|
4月前
|
运维 关系型数据库 MySQL
实时计算 Flink版产品使用问题之在处理MySQL表新增数据记录时,没有正确触发变更事件,该如何解决
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。