上篇文章我们说了索引空间和时间都是会有消耗,不要乱建索引。
当列需要作为条件,排序,分组时候可以选当前列为索引。
还要看当前列的基数,基数越大越适合做索引。
查询的时候避免%放在前面。
范围查询的时候只有左边会触发索引,除非指定精值。
索引独立存在,不可以计算或者做运算方法,这样不会触发索引。
长字符串查询的时候,对时间和空间耗费都大,这时候可以创建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)
数据目录的结构
那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是二进制文件,直接打开是会乱码的)
文章来源:知乎平台 原文地址:https://zhuanlan.zhihu.com/p/405145694