iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >Mysql怎么适当的添加索引
  • 689
分享到

Mysql怎么适当的添加索引

2024-04-02 19:04:59 689人浏览 薄情痞子
摘要

小编给大家分享一下Mysql怎么适当的添加索引,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!这里先简单介绍一下索引:添加索引是为了提高数据库查询性能,索引是最物美价廉的东西了,不用加内存,

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

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

添加索引是为了提高数据库查询性能,索引是最物美价廉的东西了,不用加内存,不用改程序,不用调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:这个值越高,说明查询低效。

看完了这篇文章,相信你对“Mysql怎么适当的添加索引”有了一定的了解,如果想了解更多相关知识,欢迎关注编程网数据库频道,感谢各位的阅读!

您可能感兴趣的文档:

--结束END--

本文标题: Mysql怎么适当的添加索引

本文链接: https://www.lsjlt.com/news/54989.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Mysql怎么适当的添加索引
    小编给大家分享一下Mysql怎么适当的添加索引,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!这里先简单介绍一下索引:添加索引是为了提高数据库查询性能,索引是最物美价廉的东西了,不用加内存,...
    99+
    2024-04-02
  • mysql添加索引的方法
    这篇文章给大家分享的是有关mysql添加索引的方法的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。一、使用CREATE INDEX语句可以使用专门用于创建索引的 CREATE IN...
    99+
    2024-04-02
  • MySQL添加索引的作用是什么
    MySQL添加索引的作用是提高查询性能。索引可以加快数据库的查询速度,特别是在查询大量数据时,可以显著减少查询的时间。通过为经常查询...
    99+
    2024-04-09
    MySQL
  • mysql添加索引的方法(Navicat可视化加索引和sql语句加索引)
    使用索引的场景: 阿里云日志里出现了慢sql  然后发现publish_works_id字段会经常用于一些关联,所以决定把这个字段加上索引,优化sql 可视化navicat操作字段加索引,选择字段所在的表,第一步:右键->设计表 第二步:...
    99+
    2023-09-22
    mysql 数据库 sql
  • MySql添加索引的几种方式
    添加索引 添加primary key(主键索引) alter table 表名 add primary key(列名); 添加unique(唯一索引) alter table 表名 add unique(列名); 添加普通索引index...
    99+
    2023-09-03
    mysql 数据库 sql
  • 怎么利用MySQL添加联合唯一索引
    本篇内容介绍了“怎么利用MySQL添加联合唯一索引”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!联合唯一索引项目中需要用到联合唯一索引:例如...
    99+
    2023-06-30
  • 使用shell脚本怎么给mysql添加索引
    本篇文章为大家展示了使用shell脚本怎么给mysql添加索引,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。用shell脚本来给mysql加索引#! /bin/bashtb_base=tb...
    99+
    2023-06-09
  • mysql添加索引方法详解(Navicat可视化加索引与sql语句加索引)
    目录使用索引的场景:下面是通过sql语句添加索引的方法:1、普通索引1)、直接创建索引2)、修改表结构的方式添加索引3)、删除索引2、唯一索引1)、创建唯一索引2)、修改表结构3、主键索引4、组合索引5、全文索引1)、创...
    99+
    2024-04-02
  • mysql添加多个btree索引的方法
    小编给大家分享一下mysql添加多个btree索引的方法,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!目前大部分数据库系统及文件系统都采用B-Tree或其变种B+Tree作为索引结构。1、B+...
    99+
    2024-04-02
  • MySQL数据库给表添加索引
    说明:当数据库中的记录数过多时,查询速度会显著变慢。此时可以给表创建索引,提高查询速度。 一、创建索引前 我现在有一张表,有1000万条记录,根据username值,查询一条记录,测试下查询时间; s...
    99+
    2023-09-18
    数据库 mysql 数学建模
  • 原则性地为MySQL索引添加
    MySQL索引添加原则及代码示例 一、引言在MySQL数据库中,索引是提高查询效率、优化数据库性能的重要手段之一。正确地添加索引可以大大减少查询时的磁盘IO操作,提高查询速度。然而,在...
    99+
    2024-02-22
    索引优化 编程实践 添加索引 mysql索引 内存占用
  • sqlserver怎么给全表添加索引
    要给一个表添加索引,可以使用以下 SQL 语句: CREATE INDEX index_name ON table_name (co...
    99+
    2024-04-09
    sqlserver
  • navicat怎样为表添加索引
    这篇文章将为大家详细讲解有关navicat怎样为表添加索引,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。navicat 为表添加索引分析常用的查询场景,为字段添加索引,增...
    99+
    2024-04-02
  • oracle怎么给表字段添加索引
    要给表字段添加索引,可以使用Oracle的CREATE INDEX语句。语法如下:```CREATE INDEX index_nam...
    99+
    2023-08-28
    oracle
  • mysql中适合加索引的字段有哪些
    这篇文章将为大家详细讲解有关mysql中适合加索引的字段有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。数据库中字段适合添加索引的有表中某个字段值离散度越高越适合,占...
    99+
    2024-04-02
  • MySQL怎样选择合适的索引
    这篇文章主要介绍了MySQL怎样选择合适的索引,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。先来看一个栗子EXPLAIN sele...
    99+
    2024-04-02
  • mysql添加索引要注意哪些事项
    在添加索引时,需要注意以下几个事项: 索引不是越多越好,过多的索引会增加数据库的存储空间和维护成本,同时也会影响数据的插入、更新...
    99+
    2024-05-13
    mysql
  • java字符串下标索引怎么添加
    在Java中,字符串是不可变的,即不能直接修改字符串的内容。但你可以通过连接操作符(+)或使用StringBuilder类来创建一个...
    99+
    2024-02-29
    java
  • mysql怎么增加唯一索引
    本篇内容主要讲解“mysql怎么增加唯一索引”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“mysql怎么增加唯一索引”吧! 三种增加...
    99+
    2024-04-02
  • 简单了解添加mysql索引的3条原则
    一,索引的重要性 索引用于快速找出在某个列中有一特定值的行。不使用索引,MySQL必须从第1条记录开始然后读完整个表直到找出相关的行。表越大,花费的时间越多。如果表中查询的列有一个索引,MySQL能快速到达...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作