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

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

  1. 当列需要作为条件,排序,分组时候可以选当前列为索引。
  2. 还要看当前列的基数,基数越大越适合做索引。
  3. 查询的时候避免%放在前面。
  4. 范围查询的时候只有最左边会触发索引,除非指定精值。
  5. 索引独立存在,不可以计算或者做运算方法,这样不会触发索引。
  6. 长字符串查询的时候,对时间和空间耗费都大,这时候可以创建hash索引或者选择字符串前几位做索引排序,若使用字符串前缀做索引,则会排序失效,用文件排序。
  7. 尽量使用覆盖索引,可以避免回表二次查询。

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

后端从入门到精通

你的鼓励是我最大的动力~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值