• mysql索引


     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, 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:这个值越高,说明查询低效。
    总结
  • 相关阅读:
    CQOI2016 不同的最小割 (最小割树模板)(等价流树的Gusfield构造算法)
    CSP2019 D2T2 划分 (单调队列DP)
    Android弱网测试中关于网络检测的一些借鉴方法
    IOS的Crash情况在Crashlytics平台上统计解决方案的一点遗憾(截止到2015年6月14日)
    关于selenium2(webdriver)自动化测试过程中标签页面或者窗口切换的处理解决方案
    针对电信乌龙事件的深度测试: 广州电信错误将深圳地区189的号码在3G升级4G申请时从广州网厅发货,造成深圳用户收到4G卡后无法激活,深圳电信找不到订单
    spring mvc + freemarker优雅的实现邮件定时发送
    使用phantomjs实现highcharts等报表通过邮件发送(本文仅提供完整解决方案和实现思路,完全照搬不去整理代码无法马上得到效果)
    模拟http或https请求,实现ssl下的bugzilla登录、新增BUG,保持会话以及处理token
    xmlrpc实现bugzilla api调用(无会话保持功能,单一接口请求)
  • 原文地址:https://www.cnblogs.com/CWQPHP/p/10488569.html
Copyright © 2020-2023  润新知