博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
MySQL 索引 总结
阅读量:5113 次
发布时间:2019-06-13

本文共 2219 字,大约阅读时间需要 7 分钟。

1.索引的种类(六种)

  普通索引,唯一索引,全文索引,单列索引,多列索引,空间索引

2.优缺点及注意事项

优点:有了索引,对于记录数量很多的表,可以提高查询速度。

缺点:索引是占用空间的,索引会影响update insert delete速度。

以下列出几点使用mysql索引的注意事项。

  a、索引要创建在where和join用到的字段上。

  b、以下操作符号可以应用索引(:<,<=,=,>,>=,BETWEEN,IN,LIKE不以%_开头)

     以下需要注意不使用索引(<>, NOT IN, LIKE %_开头)

    <> 可以用 a>1 or a<3 代替,NOT IN 可以用NOT exists代替

  c、在使用max() min()时最好加上索引。

  d、单索引要创建在确实需要的地方。多列索引有最佳左前缀特性,所以尽量左边的字段是最常用的。

  e、索引不会包括有NULL值,就是有NULL索引就失效。

  f、使用短索引,一个字段字太多,可以建立部分索引,只取前十个字节约空间。

  g、不要在列上运算。例如:where MD5("password") = "myz"。

  h、explain select * from myz 来测试一下语句的效率...

3.存储引擎和索引存储类型

  索引存储类型包含两种:B树型索引和HASH型索引

  MyISAM和InnoDB存储引擎支持B树型索引;MEMORY支持HASH型索引和B树型索引,默认是前者。

4.索引的设计原则

  a.选择唯一性索引

  b.为经常需要排序,分组和联合操作的列建立索引

  c.为常需要作为查询条件的字段建立索引

  d.限制索引的数目

  e.尽量使用数据量少的字段作为索引

  f.尽量使用前缀作为索引

  g.删除不常用的或者很少用的索引

5.创建,修改索引的SQL语句

  

CREATE TABLE 表名(属性名 数据类型 [完整性约束条件],                 属性名 数据类型 [完整性约束条件],                 ......                 [UNIQUE|FULLTEXT|SPATIAL] INDEX|KEY[别名](属性名 [(长度)] [ASC|DESC])                 );

 

 

实例

普通索引创建CREATE TABLE index1(id INT,name VARCHAR(20),sex BOOLEAN,INDEX(id));普通索引修改CREATE INDEX index1_id ON index1(id);或ALTER TABLE index1 ADD INDEX index1_id(id);

 

唯一性索引创建CREATE TABLE index2(id INT UNIQUE,name VARCHAR(20),UNIQUE INDEX index2_id(id ASC));唯一性索引修改CREATE UNIQUE index2_id ON index2(id);或ALTER TABLE index2 ADD UNIQUE INDEX index2_id(id);
全文索引创建CREATE TABLE index3(id INT,info VARCHAR(20),FULLTEXT INDEX index3_info(info))ENGINE=MyISAM;全文索引修改CREATE FULLTEXT INDEX index3_info ON index3(info);或ALTER TABLE index3 ADD FULLTEXT INDEX index3_info(info);
单列索引创建CREATE TABLE index4(id INT,subject VARCHAR(20),INDEX index4_st(subject(10)));单列索引修改CREATE INDEX index4_name ON index4(name);或ALTER TABLE index4 ADD INDEX index4_name(name);

 

多列索引创建CREATE TABLE index5(id INT,name VARCHAR(20),sex CHAR(4),INDEX index5_ns(name,sex));多列索引修改CREATE INDEX index5_ns ON index5(name,sex);或ALTER TABLE index5 ADD INDEX index_ns(name,sex);
空间索引创建CREATE TABLE index6(id INT,space GEOMETRY NOT NULL,SPATIAL INDEX index_sp(space))ENGINE=MyISAM;空间索引修改CREATE SPATIAL INDEX index6_sp ON index6(space);或ALTER TABLE index6 ADD SPATIAL INDEX index6_sp(space);

 

 

6.删除索引

  DROP INDEX 索引名 ON 表名;

 

 

 

 

 

 

 

 

 

 

  

转载于:https://www.cnblogs.com/xiaozong/p/5688310.html

你可能感兴趣的文章
前缀和
查看>>
Jquery插件汇集:
查看>>
Linux 启动、关闭、重启网络服务的两种方式
查看>>
List<T>列表通用过滤模块设计
查看>>
【模板】最小生成树
查看>>
设计模式之结构型模式
查看>>
修改navigationitem的title颜色字体阴影等属性
查看>>
前端开发中提到的“脚手架”到底指什么,CLI?gulp 和 gulp-cli有什么区别
查看>>
iis7规范URL及利用web.config进行重定向
查看>>
【Linux】入门篇 环境搭建
查看>>
poj2569
查看>>
使用mmap在内存中读写文件
查看>>
使用pygal_maps_world.i18n中数据画各大洲地图
查看>>
sql server必知多种日期函数时间格式转换
查看>>
ListView如何获取点击单元格内容
查看>>
jQuery EasyUI 的下拉选择combobox后台动态赋值
查看>>
(转)游戏引擎中三大及时光照渲染方法介绍(以unity3d为例)
查看>>
timeline时间轴进度“群英荟萃”
查看>>
python map函数用法
查看>>
ios之申请后台延时执行和做一个假后台的方法(系统进入长时间后台后,再进入前台部分功能不能实现)...
查看>>