1. 假设你使用了Innodb存储引擎
2. 假设你在innodb设定了主键(汇集索引)设计
3. 由于汇集索引页面之间是经过双向链表连接,页按照主键的顺序排序
每一个页中的记录也是经过双向链表维护。汇集索引上存储了主键的值
因为B+树的特性,最左端的叶子节点存储最小的值,最右端的叶子节点存储最大的值。
4. 最小值的通常方法:咱们能够看到没有使用key,设计的行299600行
root:employees 11:00 > select min(emp_no) from employees where gender='M';
+-------------+
| min(emp_no) |
+-------------+
| 10001 |
+-------------+
1 row in set (0.11 sec)排序
root:employees 11:07 > explain select min(emp_no) from employees where gender='M';
+----+-------------+-----------+------+---------------+------+---------+------+--------+-------------+
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
+----+-------------+-----------+------+---------------+------+---------+------+--------+-------------+
| 1 | SIMPLE | employees | ALL | NULL | NULL | NULL | NULL | 299600 | Using where |
+----+-------------+-----------+------+---------------+------+---------+------+--------+-------------+索引
5. 利用上面的说明,取出最左端的叶子节点便可。此时咱们看到执行时间很短,虽然explain结果比较困惑!
root:employees 11:12 > select emp_no from employees USE INDEX(PRIMARY) where gender='M' limit 1;
+--------+
| emp_no |
+--------+
| 10001 |
+--------+
1 row in set (0.00 sec)it
root:employees 11:13 > explain select emp_no from employees USE INDEX(PRIMARY) where gender='M' limit 1;
+----+-------------+-----------+------+---------------+------+---------+------+--------+-------------+
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
+----+-------------+-----------+------+---------------+------+---------+------+--------+-------------+
| 1 | SIMPLE | employees | ALL | NULL | NULL | NULL | NULL | 299600 | Using where |
+----+-------------+-----------+------+---------------+------+---------+------+--------+-------------+innodb
6. 一样咱们执行max最大值的时候,能够先倒排在取出第一个数据。由于页之间经过双向链表连接。
root:employees 11:18 > select max(emp_no) from employees where gender='M';
+-------------+
| max(emp_no) |
+-------------+
| 499999 |
+-------------+
1 row in set (0.22 sec)table
root:employees 11:18 > select emp_no from employees USE INDEX(PRIMARY) where gender='M' order by emp_no desc limit 1;
+--------+
| emp_no |
+--------+
| 499999 |
+--------+
1 row in set (0.00 sec)select
root:employees 11:18 > explain select emp_no from employees USE INDEX(PRIMARY) where gender='M' order by emp_no desc limit 1;
+----+-------------+-----------+-------+---------------+---------+---------+------+------+-------------+
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
+----+-------------+-----------+-------+---------------+---------+---------+------+------+-------------+
| 1 | SIMPLE | employees | index | NULL | PRIMARY | 4 | NULL | 1 | Using where |
+----+-------------+-----------+-------+---------------+---------+---------+------+------+-------------+方法
7.咱们在查询范围的使用,也能够利用B+树的特性来迅速查询到咱们想要的信息。由于B+树的索引页存储了主键的范围;
root:employees 11:22 > explain select emp_no from employees USE INDEX(PRIMARY) where gender='M' order by emp_no desc limit 1;
+----+-------------+-----------+-------+---------------+---------+---------+------+------+-------------+
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
+----+-------------+-----------+-------+---------------+---------+---------+------+------+-------------+
| 1 | SIMPLE | employees | index | NULL | PRIMARY | 4 | NULL | 1 | Using where |
+----+-------------+-----------+-------+---------------+---------+---------+------+------+-------------+im