Mysql怎么适当的添加索引

  介绍

小编给大家分享一下Mysql怎么适当的添加索引,希望大家阅读完这篇文章之后都有所收获、下面让我们一起去探讨吧!

<强>这里先简单介绍一下索引:

添加索引是为了提高数据库查询性能,索引是最物美价廉的东西了,不用加内存,不用改程序,不用调sql,只要执行个正确的创建索引,查询的速度就可能提高百倍千倍,这可是有诱惑力的,可是天下没有没费的午餐,查询的速度的提高是以牺牲插入、更新、删除的速度为代价的。而且索引大小一般是数据的三分之一,,再加上索引要加载进内存的,如果全部字段都加索引会以牺牲内存为代价的,所以才要设当的添加索引。

<强>这里简单介绍一下mysql中常用索引:

在添加索引之前最好先查看一下该表中已存在哪些索引:显示指数从表名;

<强> 1,主键索引

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

主键索引:一般在建表的时候就添加了比如:id一般是主键索引加自动递增。

建表后添加主键索引:<代码> alter table table_name添加主键(列名);

主键索引的特点:不能为空且唯一。

<强> 2,普通索引

创建普通索引:,<代码> alter table table_name添加索引索引名(column1 column2);

<强> 3,唯一索引

创建唯一索引:<代码> alter table的table_name添加独特的(“列”);

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

唯一索引:可以有多个零但数据内容不能重复

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

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

<强> 4,全文索引

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

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

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

CREATE  TABLE “文章”,(   ,,,“id”, int (10), unsigned  NOT  NULL  AUTO_INCREMENT,   ,,,,“标题”,varchar (200), DEFAULT 空,   ”,,,,内容”,文本,   ,,,,,PRIMARY  KEY  (id),   ,,,,,FULLTEXT  KEY “标题”,(“标题”,“内容”)   ,,,,,),=MyISAM引擎(5.6之后InnoDB也支持全文索引,,5.7不支持MyISAM引擎),DEFAULT  CHARSET=use utf8;

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

ALTER  TABLE  article  ADD  FULLTEXT  INDEX  fulltext_article(标题、内容),

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

众所周知在数据库中进行模糊查询是使用像关键字进行查询的,例如:

SELECT  *,得到article  WHERE  content  LIKE  %查询字符串% & # 39;;

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

SELECT  *,得到article  WHERE 匹配(标题、内容),AGAINST ('查询字符串& # 39;);

强烈注意:MySql自带的全文索引只能对英文进行全文检索,目前无法对中文进行全文检索。如果需要对包含中文在内的文本数据进行全文检索,我们需要采用斯芬克斯(斯芬克斯)/Coreseek技术来处理中文。

注:目前,使用MySql自带的全文索引时,如果查询字符串的长度过短将无法得到期望的搜索结果.MySql全文索引所能找到的词默认最小长度为4个字符。另外,如果查询的字符串包含停止词,那么该停止词将会被忽略。

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

删除索引sql语句:<代码> alter table table_name下降指数索引名;

<强>通过上面的简单介绍后,那么应该在哪些字段上添加索引呢?

,1,才能频繁查询的字段,应该创建索引。

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

,,3,唯一性太差的字段,比如性别字段,就不应该创建索引。

,,4,不会出现在在条件之后的字段,不应该创建索引。

满足一下条件,应该创建索引:

,,,,,,1、频繁要查询的字段,经常出现在在条件后面的字段,应该创建索引。

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

<>强索引使用的注意事项

Mysql怎么适当的添加索引