mysql 的索引介绍及使用

mysql 的主键索引使用及介绍

– 给表上的字段加索引 目的是为了 更加快速的搜索,如果我给这个字段加了索引,
– 那么这个字段的存值 就会有一定的排序,然后我在执行sql的时候 它就会分区域范围性的查找,
– 就像主键,主键是唯一性的 它自己给自己创建了一个唯一索引,这样就很快的定位到了目标
– mysql在使用like查询的时候只有使用后面的%时,才会使用到索引。
– mysql的5个索引
– 主键索引
CREATE TABLE testwen0 (
ID INT(11) NOT NULL AUTO_INCREMENT,
PRIMARY KEY (ID)
– 此关键字创建主键时,自动创建唯一索引
) ENGINE=INNODB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8;

– 普通索引
CREATE TABLE testwen (
ID INT(11) NOT NULL AUTO_INCREMENT,
NAME VARCHAR(20) DEFAULT NULL,
PRIMARY KEY (ID),
KEY (NAME) USING BTREE
) ENGINE=INNODB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8;
– 添加索引
CREATE INDEX NAME ON testwen(NAME)
– 此字段会根据排序索引的一定规则排列 使用该字段进行查询时会很快

– 全文索引
CREATE TABLE testwen1 (
ID INT(11) NOT NULL AUTO_INCREMENT,
NAME VARCHAR(20) DEFAULT NULL,
INTRODUCE VARCHAR(100),
PRIMARY KEY (ID),
KEY (NAME),
FULLTEXT KEY (INTRODUCE)
) ENGINE=INNODB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8;
– 添加索引
CREATE FULLTEXT INDEX INTRODUCE ON testwen1(INTRODUCE);
– 全文索引,用于在一篇文章中,快速检索文本信息的。

– 组合索引
CREATE TABLE testwen2 (
ID INT(11) NOT NULL AUTO_INCREMENT,
NAME VARCHAR(20) DEFAULT NULL,
INTRODUCE VARCHAR(100) DEFAULT NULL,
AGE INT(2) DEFAULT NULL,
PRIMARY KEY (ID),
KEY NAME (NAME) USING BTREE,
KEY NAME_AGE (NAME,AGE) USING BTREE,
FULLTEXT KEY INTRODUCE (INTRODUCE)
) ENGINE=INNODB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8;
– 添加索引
CREATE INDEX NAME_AGE ON testwen2(NAME,AGE)

– 聚簇索引 不常使用 不想动脑子了
– 如上总结
– 比如建立一张个人信息表,个人编号 int 、 个人姓名 VARCHAR(20)、个人身份证信息VARCHAR(40)、客户电话VARCHAR(20)、客户住址VARCHAR(100)、个人备注信息 text
– 这个时候 个人编码作为主键使用 PRIMARY
– 个人姓名 如果要建索引的话,就用普通的 INDEX
– 个人身份证号码 如果要建索引的话,那么就使用 UNIQUE (唯一的,不允许重复)
– 个人备注信息,如果需要建索引的话,可以选择 FULLTEXT,全文搜索。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值