前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Mysql数据目录(1)---数据库结构(二十四)

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

作者头像
用户9919783
发布2022-07-26 12:24:34
6830
发布2022-07-26 12:24:34
举报
文章被收录于专栏:后端从入门到精通

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

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

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

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

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

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

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

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

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

Mysql数据目录

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

数据目录

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

代码语言:javascript
复制
mysql> show variables like 'datadir';
+---------------+------------------------+
| Variable_name | Value                  |
+---------------+------------------------+
| datadir       | /usr/local/mysql/data/ |
+---------------+------------------------+
1 row in set (0.00 sec)

数据目录的结构

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

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

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

代码语言:javascript
复制
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是二进制文件,直接打开是会乱码的)

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-08-30,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 后端从入门到精通 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Mysql数据目录
相关产品与服务
对象存储
对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档