百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>数据库> Mysql怎样恰当的增加索引介绍
分享文章到:

Mysql怎样恰当的增加索引介绍

发布时间:05/13 来源:未知 浏览: 关键词:

这里先简略介绍一下索引:

增加索引是为了提高数据库查询机能,索引是最物美价廉的东西了,不用加内存,不用改程序,不用调sql,只有施行个准确的create index ,查询的速度就可能提高百倍千倍,这可是有诱惑力的,可是世界没有没费的午饭,查询的速度的提高是以牺牲insert update delete的速度为代价的。而且索引大小个别是数据的三分之一  ,再加上索引要加载进内存的,要是全部字段都加索引会以牺牲内存为代价的,所以才要设当的增加索引。

这里简略介绍一下mysql中常用索引:

在增加索引以前最佳先查看一下该表中已存在哪些索引:show index from 表名;

1、主键索引

注意: 主键索引一张表中只能有一个,但是可以增加多个索引 比方:独一索引、普通索引、全文索引。

主键索引:个别在建表的时候就增加了 比方:id 个别是主键索引加主动递增。

建表后增加主键索引 :alter table table_name add primary key (column name);

主键索引的特色:不能为空且独一。

2、普通索引

创建普通索引: alter table table_name add index 索引名(column1,column2);

3、独一索引

创建独一索引:ALTER TABLE `table_name` ADD UNIQUE (`column`);

独一索引与主键索引的区别:

独一索引:可以有多个null 但数据内容不能反复

主键索引:不能为null,且内容只能独一。

两个区别就在于主键索引不能为null 独一索引可以有多个null 其余都同样。

4、全文索引

全文索引只要MyISAM有效(mysql5.6之后InnoDB也支撑了全文索引)[5.7不支撑MyISAM]

全文索引主要针对文本文件,比方文章、标题。

在创建表时创建全文索引:

    CREATE TABLE `article` (
    `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
     `title` varchar(200) DEFAULT NULL,
 `    content` text,
      PRIMARY KEY (`id`),
      FULLTEXT KEY `title` (`title`,`content`)
      ) ENGINE=MyISAM(5.6之后InnoDB也支撑全文索引 、5.7不支撑MyISAM引擎) DEFAULT CHARSET=utf8;

在现有表中创建全文索引:

ALTER TABLE article ADD FULLTEXT INDEX fulltext_article(title,content);

创建完全文索引之后运用也有要注意的地方:

众所周知在数据库中进行依稀查询是运用like要害字进行查询的,例如:

SELECT * FROM article WHERE content LIKE ‘%查询字符串%';

那么,我们在运用全文索引也这样运用吗?当然不是,我们必须运用特有的语法才能运用全文索引进行查询,例如,我们想要在article表的title和content列中全文检索指定的查询字符串,我们可以如下编写SQL语句:

SELECT * FROM article WHERE MATCH(title,content) AGAINST (‘查询字符串');

热烈注意:MySql自带的全文索引只能对英文进行全文检索,当前没法对中文进行全文检索。要是需要对包含中文在内的文本数据进行全文检索,我们需要采纳Sphinx(斯芬克斯)/Coreseek技术来处置中文。

注:当前,运用MySql自带的全文索引时,要是查询字符串的长度过短将没法得到奢望的搜寻效果。MySql全文索引所能找到的词默许最小长度为4个字符。另外,要是查询的字符串包含休止词,那么该休止词将会被忽略。

要是可能,请尽量先创建表并插入所有数据后再创建全文索引,而不要在创建表时就直接创建全文索引,由于前者比后者的全文索引效率要高。

删除索引sql语句:alter table table_name drop index 索引名;

通过上面的简略介绍后,那么应当在哪些字段上增加索引呢?

    1、 频繁查询的字段,应当创建索引。

    2、更新非常频繁的字段,不应当创建索引。

    3、独一性太差的字段,比方 gender字段,就不应当创建索引。

    4、不会涌现在where前提之后的字段,不应当创建索引。

知足一下前提,应当创建索引:

        1、频繁要查询的字段,经常涌现在where前提背面的字段,应当创建索引。

        2、更新不频繁的字段,可以创建索引。

索引运用的注意事项

    1.关于创建的多列索引,只有查询前提运用了最左边的列,索引个别就会被运用。

  •             比方我们对title,content 增加了复合索引
  •             select * from table_name where title = 'test';会用到索引
  •             select * from table_name where content = 'test';不会用到索引

    2.关于运用like的查询,查询要是是 ‘%a'不会运用到索引 ,而 like 'a%'就会用到索引。最前面不能运用%和_这样的变化值

    3.要是前提中有or,即便其中有前提带索引也不会运用。

    4.要是列类型是字符串,那一定要在前提中将数据运用引号援用起来。

  •         查看索引的运用状况:show status like‘Handler_read%';  
  •         handler_read_key:这个值越高越好,越高表示运用索引查询到的次数。
  •         handler_read_rnd_next:这个值越高,注明查询低效。

总结

以上就是这篇文章的全部内容了,但愿本文的内容对大家的学习或者工作拥有一定的参考学习价值,感谢大家对脚本之家的支撑。要是你想理解更多相干内容请查看下面相干链接

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有160人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板