首页 / MYSQL / MySQL 索引 总结
MySQL 索引 总结
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了MySQL 索引 总结,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2775字,纯文字阅读大概需要4分钟。
内容图文
![MySQL 索引 总结](/upload/InfoBanner/zyjiaocheng/468/8b3b2934946c43d884349628b1ce7ace.jpg)
普通索引,唯一索引,全文索引,单列索引,多列索引,空间索引
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 表名;
MySQL 索引 总结
标签:
本文系统来源:http://www.cnblogs.com/xiaozong/p/5688310.html
内容总结
以上是互联网集市为您收集整理的MySQL 索引 总结全部内容,希望文章能够帮你解决MySQL 索引 总结所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。