Mysql数据目录(1)---数据库结构(二十四)

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

上篇文章我们说了索引空间和时间都是会有消耗,不要乱建索引。

当列需要作为条件,排序,分组时候可以选当前列为索引。

还要看当前列的基数,基数越大越适合做索引。

查询的时候避免%放在前面。

范围查询的时候只有最左边会触发索引,除非指定精值。

索引独立存在,不可以计算或者做运算方法,这样不会触发索引。

长字符串查询的时候,对时间和空间耗费都大,这时候可以创建hash索引或者选择字符串前几位做索引排序,若使用字符串前缀做索引,则会排序失效,用文件排序。

尽量使用覆盖索引,可以避免回表二次查询。

B+树挑选索引(2)---mysql从入门到精通(二十三)


Mysql数据目录


我们都知道innoDB和myISAM存储引擎都是吧数据存储在磁盘上,而操作系统管理磁盘的又是文件系统,所以像nnoDB和myISAM这样的存储引擎都是吧数据存储在文件系统中。当我们读取数据的时候,就从文件系统中吧数据读取出来,当我们写入数据的时候,存储引擎又会吧数据写入文件系统。


数据目录


Mysql在启动的时候,会在文件系统的一个目录下下载一些文件,然后在运行的过程中产生的数据也会放在这个目录下,称为数据目录。我们之前安装mysql的时候指定mysql的安装目录,里面有不少可执行的文件,我们这里讲的数据目录一定要和安装目录区分开,那我们如何查看自己 mysql的数据目录呢?数据目录对应的系统变量是datadir,我们只要输入当前命令就可以看到:

mysql> show variables like 'datadir';
+---------------+------------------------+
| Variable_name | Value                  |
+---------------+------------------------+
| datadir       | /usr/local/mysql/data/ |
+---------------+------------------------+
1 row in set (0.00 sec)


数据目录的结构


那mysql在运行的时候会产生哪些数据呢?当然是我们创建的数据库,表,视图,触发器,等用户数据,除了这些数据,mysql为了更好地运行,提高效率,也会有一些额外数据。


数据库在文件系统中的表示


建表先从指定数据库,那我们从创建数据库,数据库在文件系统中的表示开始说起,我们在create database ‘’,发生了什么呢?

keying@B-D226JG5H-0020 mysql % cd data 
keying@B-D226JG5H-0020 data % ls
B-D226JG5H-0020.local.err mysql
B-D226JG5H-0020.local.pid mysqld.local.err
auto.cnf      mysqld.local.pid
dev       mysqld_safe.pid
ib_buffer_pool      performance_schema
ib_logfile0     sys
ib_logfile1     testmac
ibdata1       utf_8
ibtmp1

查看数据文件data目录下,我们可以看到我们创建的各种数据库,所以当你运行create database ''的 时候:

1)会在数据目录下,创建数据库同名的子目录。

2)进入指定数据库文件,可以看到默认创建的db.opt文件,里面存放着当前数据库的规则,特征,如比较规则,字符集等。


表在文件系统中的位子


表分为两个部分:1)表结构文件。2)表数据文件。

当我们create table ''一个表时候,会在数据库文件目录下,创建一个表名.frm的文件。比如我们有index_page_tb,所以在utf_8的目录下会有一个index_page_tb.frm的文件记录着当前表的结构,比如有表的行规则,字符集,每列的数据类型,索引等。值得注意的是innoDB和mISAM都是会创建.frm文件来记录当前表的结构,但是存储的数据是不同的。下一篇文章我们来看数据的存储文件。(注意:.frm是二进制文件,直接打开是会乱码的)

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
10天前
|
数据采集 数据库 Python
有哪些方法可以验证用户输入数据的格式是否符合数据库的要求?
有哪些方法可以验证用户输入数据的格式是否符合数据库的要求?
119 75
|
23天前
|
SQL 存储 运维
从建模到运维:联犀如何完美融入时序数据库 TDengine 实现物联网数据流畅管理
本篇文章是“2024,我想和 TDengine 谈谈”征文活动的三等奖作品。文章从一个具体的业务场景出发,分析了企业在面对海量时序数据时的挑战,并提出了利用 TDengine 高效处理和存储数据的方法,帮助企业解决在数据采集、存储、分析等方面的痛点。通过这篇文章,作者不仅展示了自己对数据处理技术的理解,还进一步阐释了时序数据库在行业中的潜力与应用价值,为读者提供了很多实际的操作思路和技术选型的参考。
37 1
|
27天前
|
存储 Java easyexcel
招行面试:100万级别数据的Excel,如何秒级导入到数据库?
本文由40岁老架构师尼恩撰写,分享了应对招商银行Java后端面试绝命12题的经验。文章详细介绍了如何通过系统化准备,在面试中展示强大的技术实力。针对百万级数据的Excel导入难题,尼恩推荐使用阿里巴巴开源的EasyExcel框架,并结合高性能分片读取、Disruptor队列缓冲和高并发批量写入的架构方案,实现高效的数据处理。此外,文章还提供了完整的代码示例和配置说明,帮助读者快速掌握相关技能。建议读者参考《尼恩Java面试宝典PDF》进行系统化刷题,提升面试竞争力。关注公众号【技术自由圈】可获取更多技术资源和指导。
|
4天前
|
缓存 关系型数据库 MySQL
【深入了解MySQL】优化查询性能与数据库设计的深度总结
本文详细介绍了MySQL查询优化和数据库设计技巧,涵盖基础优化、高级技巧及性能监控。
56 0
|
30天前
|
前端开发 JavaScript 数据库
获取数据库中字段的数据作为下拉框选项
获取数据库中字段的数据作为下拉框选项
58 5
|
1月前
|
存储 Oracle 关系型数据库
数据库传奇:MySQL创世之父的两千金My、Maria
《数据库传奇:MySQL创世之父的两千金My、Maria》介绍了MySQL的发展历程及其分支MariaDB。MySQL由Michael Widenius等人于1994年创建,现归Oracle所有,广泛应用于阿里巴巴、腾讯等企业。2009年,Widenius因担心Oracle收购影响MySQL的开源性,创建了MariaDB,提供额外功能和改进。维基百科、Google等已逐步替换为MariaDB,以确保更好的性能和社区支持。掌握MariaDB作为备用方案,对未来发展至关重要。
61 3
|
1月前
|
安全 关系型数据库 MySQL
MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!
《MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!》介绍了MySQL中的三种关键日志:二进制日志(Binary Log)、重做日志(Redo Log)和撤销日志(Undo Log)。这些日志确保了数据库的ACID特性,即原子性、一致性、隔离性和持久性。Redo Log记录数据页的物理修改,保证事务持久性;Undo Log记录事务的逆操作,支持回滚和多版本并发控制(MVCC)。文章还详细对比了InnoDB和MyISAM存储引擎在事务支持、锁定机制、并发性等方面的差异,强调了InnoDB在高并发和事务处理中的优势。通过这些机制,MySQL能够在事务执行、崩溃和恢复过程中保持
79 3
|
1月前
|
SQL 关系型数据库 MySQL
数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog
《数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog》介绍了如何利用MySQL的二进制日志(Binlog)恢复误删除的数据。主要内容包括: 1. **启用二进制日志**:在`my.cnf`中配置`log-bin`并重启MySQL服务。 2. **查看二进制日志文件**:使用`SHOW VARIABLES LIKE 'log_%';`和`SHOW MASTER STATUS;`命令获取当前日志文件及位置。 3. **创建数据备份**:确保在恢复前已有备份,以防意外。 4. **导出二进制日志为SQL语句**:使用`mysqlbinlog`
94 2
|
1月前
|
关系型数据库 MySQL 数据库
Python处理数据库:MySQL与SQLite详解 | python小知识
本文详细介绍了如何使用Python操作MySQL和SQLite数据库,包括安装必要的库、连接数据库、执行增删改查等基本操作,适合初学者快速上手。
272 15
|
1月前
|
SQL 关系型数据库 MySQL
数据库数据恢复—Mysql数据库表记录丢失的数据恢复方案
Mysql数据库故障: Mysql数据库表记录丢失。 Mysql数据库故障表现: 1、Mysql数据库表中无任何数据或只有部分数据。 2、客户端无法查询到完整的信息。