MySQL的索引

介绍:
索引是通过某种算法,构建出一个数据模型,用于快速找出在某个列中有一特定值的行,不使用索引,MySQL必须从第一条记录开始读完整个表,直到找出相关的行,表越大,查询数据所花费的时间就越多,如果表中查询的列有一个索引,MySQL能够快速达到一个位置去搜索数据文件,而不必查看所有数据,那么将会节省很大一部分时间。

分类

索引是存储引擎用来快速查找的记录的一种数据结构,按照实现的方式类分,主要有HASH索引和B+TREE索引

创建索引

单列索引:一个索引只包含单个列,但一个表中可以有多个单列索引
普通索引:MySQL中基本索引类型,没有什么限制,允许在定义索引的列中插入重复值和控制,纯粹为了查询数据快一点。

单列索引

普通索引

创建操作
例如:

CREATE DATABASE mydb5;
USE mydb5;

-- 方式一 -创建表的时候直接指定
CREATE TABLE student(
	sid INT PRIMARY KEY,
	card_id VARCHAR(50),
	name VARCHAR(50),
	gender VARCHAR(20),
	age INT,
	birth DATE,
	phone_num VARCHAR(20),
	score DOUBLE,
	INDEX index_name(name) -- 给name列创建索引
);
SELECT * FROM student WHERE name='张三';

-- 第二种方式 - 直接创建
CREATE INDEX index_gender ON student(gender);

-- 第三种方式 - 修改表结构(添加索引)
ALTER TABLE student ADD INDEX index_age(age);

查看操作
例如:

-- 1.查看数据库所有索引
SELECT * FROM mysql.innodb_index_stats a WHERE a.database_name='mydb5';

-- 2.查看表中所有索引
SELECT * FROM mysql.innodb_index_stats a WHERE a.d
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

火眼猊

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值