mysql索引

1.索引的快速入门

说起提高数据库性能,索引是最物美价廉的东西了,不用加内存,不用改程序,不用调sql,查询速度就可能提高百倍千倍

2.索引的原理
没有索引为什么会慢?因为全表扫描
使用索引为什么会快?形成一个索引的数据结构
索引的代价
(1)磁盘占用
(2)对增删改语句的效率影响(平时在我们的项目中,select占据90%)
3.索引的类型
(1)主键索引,主键自动为主索引(类型Primary key)
(2) 唯一索引
(3)普通索引
(4)全文索引
create table t1(
iid int primary key --主键,同时也是索引,称为主键索引
name varchar(32);
create table t2(
id int unique, --id是唯一的,同时也是索引,称为unique索引
4.索引的使用
-- 演示 mysql 的索引的使用
-- 创建索引
CREATE TABLE t25 (
id INT ,
`name` VARCHAR(32));
-- 查询表是否有索引
SHOW INDEXES FROM t25;
-- 添加索引
-- 添加唯一索引
CREATE UNIQUE INDEX id_index ON t25 (id);
-- 添加普通索引方式 1
CREATE INDEX id_index ON t25 (id);
-- - 如何选择
-- 1. 如果某列的值,是不会重复的,则优先考虑使用 unique 索引 , 否则使用普通索引
-- 添加普通索引方式 2
ALTER TABLE t25 ADD INDEX id_index (id)
-- 添加主键索引
CREATE TABLE t26 (
id INT ,
`name` VARCHAR(32));
ALTER TABLE t26 ADD PRIMARY KEY (id)
SHOW INDEX FROM t25
-- 删除索引
DROP INDEX id_index ON t25
-- 删除主键索引
ALTER TABLE t26 DROP PRIMARY KEY
-- 修改索引 , 先删除,在添加新的索引
-- 查询索引
-- 1. 方式
SHOW INDEX FROM t25
-- 2. 方式
SHOW INDEXES FROM t25
5.索引使用的场景
(1)较频繁的作为查询字段应该创建索引
(2)唯一性太差的字段不适合单独创建索引,即使频繁作为查询条件
如性别为男
(3)更行非常频繁的字段不适合创建索引
(4)不会出现在Where子句中字段不应该创建索引
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值