雄安网站建设制作,事件营销成功案例有哪些,个人网站设计模板,重庆市公共资源交易中心网官网1 查看表中已存在哪些索引#xff1a;show index from 表名#xff1b;在添加索引之前最好先查看一下该表中已存在哪些索引#xff1a;show index from 表名#xff1b;1、主键索引注意#xff1a; 主键索引一张表中只能有一个#xff0c;但是可以添加多个索引 比如…1 查看表中已存在哪些索引show index from 表名在添加索引之前最好先查看一下该表中已存在哪些索引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,PRIMARYKEY (id),FULLTEXTKEY title (title,content)) ENGINEMyISAM(5.6之后InnoDB也支持全文索引 、5.7不支持MyISAM引擎) DEFAULT CHARSETutf8;在现有表中创建全文索引ALTER TABLE article ADD FULLTEXT INDEX fulltext_article(title,content);创建完全文索引之后使用也有要注意的地方众所周知在数据库中进行模糊查询是使用like关键字进行查询的例如SELECT *FROM articleWHERE contentLIKE ‘%查询字符串%;那么我们在使用全文索引也这样使用吗当然不是我们必须使用特有的语法才能使用全文索引进行查询例如我们想要在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:这个值越高说明查询低效。总结