Mysql数据库 15.SQL语言 索引

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: Mysql数据库 15.SQL语言 索引

一、索引的介绍

数据库是用来存储数据,在互联网应用中数据库中存储的数据可能会很多(大数据),数据表中数据的查询速度会随着数据量的增长逐渐缓慢,从而导致用户请求的速度变慢——用户体验变差


索引,就是用来提高数据表中数据的查询效率的


当我们进行数据查询的时候,会生成一个“目录”,避免我们要全局查询


事先准备

1、声明数据库

use db_test2;


2、创建表

create table tb_testindex (
  fid int primary key,
  sid int unique,
  tid int,
  name varchar(20),
  remark varchar(20)
);

3、创建存储过程

#创建储存过程
create procedure proc_readydata(
begin
  declare i int default 1;
  while i<=5000000 do
    insert into tb_testindex (fid,sid,tid,name,remark)
      values(i,i,i,'test_name','text_remark');
    set i=i+1;
  end while;
end;

4.调用存储过程

call+存储过程名;

5、当数据量巨大时,引入索引

二、索引的分类

三、创建索引


查看目前所有索引

语法


show keys from 表名;

#查询当前索引
show keys from tb_testindex ;

创建唯一索引

创建具体哪个表和列的唯一索引

create 约束 index关键字 索引名 on 表名(列名);

create unique index index_test1 on tb_testindex(tid);

创建普通索引

create index 索引名 on 表名(列名);

create index index_test2 on tb_testindex(name);

创建组合索引

将多个字段组合起来作为索引存在()括号中有多个字段(列)

create index index_test3 on tb_testindex(tid,name);

全文索引

四、索引使用

#索引使用 内部已经使用索引
select * from tb_testindex tt where tid=250000;

查看索引

1.在Mysql中查看索引

explain select * from tb_testindex表名 where tid列名=25000数据量\G;


2.在命令行窗口查看

使用数据库


use db_test2;


show create table 表名 index\G;


3.可视化工具查看索引

show indexes from 表名;


show indexes from tb_testindex ;



删除索引

drop index 索引名 on 表名;


drop index index_test3 on tb_testindex;


五、索引的使用总结


相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
1天前
|
存储 SQL 数据库
数据库sql语句-----游标和存储过程
数据库sql语句-----游标和存储过程
12 1
|
1天前
|
SQL Oracle 关系型数据库
实验四 SQL语言
实验四 SQL语言
6 2
|
1天前
|
关系型数据库 MySQL 数据库
mysql 设置环境变量与未设置环境变量连接数据库的区别
设置与未设置MySQL环境变量在连接数据库时主要区别在于命令输入方式和系统便捷性。设置环境变量后,可直接使用`mysql -u 用户名 -p`命令连接,而无需指定完整路径,提升便利性和灵活性。未设置时,需输入完整路径如`C:\Program Files\MySQL\...`,操作繁琐且易错。为提高效率和减少错误,推荐安装后设置环境变量。[查看视频讲解](https://www.bilibili.com/video/BV1vH4y137HC/)。
22 3
mysql 设置环境变量与未设置环境变量连接数据库的区别
|
1天前
|
SQL 数据库
数据库SQL语言实战(六)
本次实战的重点就在于对表格本身的一些处理,包括复制表格、修改表格结构、修改表格数据
|
1天前
|
SQL Oracle 关系型数据库
数据库SQL语言实战(五)(数据库系统概念第三章练习题)
本文的SQL语言适用的是Oracle数据库与mySQL可能存在略微不同
|
1天前
|
SQL Oracle 关系型数据库
数据库SQL语言实战(四)(数据库系统概念第三章练习题)
本文的SQL语言适用的是Oracle数据库与mySQL可能存在略微不同
数据库SQL语言实战(四)(数据库系统概念第三章练习题)
|
1天前
|
关系型数据库 MySQL 数据库
docker MySQL删除数据库时的错误(errno: 39)
docker MySQL删除数据库时的错误(errno: 39)
19 0
|
1天前
|
关系型数据库 MySQL 数据库连接
用Navicat备份Mysql演示系统数据库的时候出:Too Many Connections
用Navicat备份Mysql演示系统数据库的时候出:Too Many Connections
18 0
|
1天前
|
存储 Oracle 关系型数据库
oracle 数据库 迁移 mysql数据库
将 Oracle 数据库迁移到 MySQL 是一项复杂的任务,因为这两种数据库管理系统具有不同的架构、语法和功能。
22 0
|
1天前
|
关系型数据库 MySQL Linux
【MySQL-10】数据库函数-案例演示【字符串/数值/日期/流程控制函数】(代码演示&可cv代码)
【MySQL-10】数据库函数-案例演示【字符串/数值/日期/流程控制函数】(代码演示&可cv代码)
【MySQL-10】数据库函数-案例演示【字符串/数值/日期/流程控制函数】(代码演示&可cv代码)