加入收藏 | 设为首页 | 会员中心 | 我要投稿 财气旺网 - 海宁网 (https://www.hainingwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 移动互联 > 正文

MySQL5.7中的函数索引怎么用

发布时间:2021-12-20 12:18:41 所属栏目:移动互联 来源:互联网
导读:本篇文章给大家分享的是有关MySQL5.7中的函数索引怎么用,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。 在MySQL5.7之前的版本中,函数索引是无法用到索引的,也不支持虚拟列,下边的SQL执
本篇文章给大家分享的是有关MySQL5.7中的函数索引怎么用,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。
 
 在MySQL5.7之前的版本中,函数索引是无法用到索引的,也不支持虚拟列,下边的SQL执行时候回进行全表扫描:
 select * from t1 where mod(mode_id,8)=1
 MySQL5.7支持虚拟列,并且可以使用函数索引。
 确定数据库版本:
 
mysql> select version();
+------------+
| version() |
+------------+
| 5.7.18-log |
+------------+
  查看表结构:
 
mysql> show create table t_func_mod G
*************************** 1. row ***************************
       Table: t_func_mod
Create Table: CREATE TABLE `t_func_mod` (
  `id` int(11) NOT NULL,
  `mod_id` int(11) GENERATED ALWAYS AS ((`id` % 8)) VIRTUAL,
  PRIMARY KEY (`id`),
  KEY `idx_mod_id` (`mod_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
  插入测试数据:
 
 
mysql> insert into t_func_mod values(1,default);
Query OK, 1 row affected (0.08 sec)
mysql> insert into t_func_mod values(2,default);
Query OK, 1 row affected (0.06 sec)
mysql> insert into t_func_mod values(3,default);
Query OK, 1 row affected (0.01 sec)
mysql> insert into t_func_mod values(4,default);
Query OK, 1 row affected (0.01 sec)
mysql> insert into t_func_mod values(5,default);
Query OK, 1 row affected (0.04 sec)
mysql> insert into t_func_mod values(6,default);
Query OK, 1 row affected (0.00 sec)
mysql> insert into t_func_mod values(7,default);
Query OK, 1 row affected (0.00 sec)
mysql> insert into t_func_mod values(8,default);
Query OK, 1 row affected (0.00 sec)
  注意:插入数据时候,虚拟列要使用default,否则会报错。
 查看测试表数据:
 
 
mysql> select * from t_func_mod;
+----+--------+
| id | mod_id |
+----+--------+
| 8 | 0 |
| 1 | 1 |
| 2 | 2 |
| 3 | 3 |
| 4 | 4 |
| 5 | 5 |
| 6 | 6 |
| 7 | 7 |
+----+--------+
通过explain查看执行计划,已经使用到了索引:
 
 
mysql> explain select * from t_func_mod where mod_id=5;
----+-------------+------------+------------+------+---------------+------------+---------+-------+------+----------+-------------+
| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |
+----+-------------+------------+------------+------+---------------+------------+---------+-------+------+----------+-------------+
| 1 | SIMPLE | t_func_mod | NULL | ref | idx_mod_id | idx_mod_id | 5 | const | 1 | 100.00 | Using index |
以上就是MySQL5.7中的函数索引怎么用,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注亿速云行业资讯频道。

(编辑:财气旺网 - 海宁网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!