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

2023-01-31 00:00:00 索引 数据 文件 都是 文件系统

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

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

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

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

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

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

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

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

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)

相关文章