首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Mysql合理建立索引,索引优化

写下这篇文章就是为了记录一下对索引的优化,合理建立索引。 什么是索引 MySQL官方对索引的定义为:索引(Index)是帮助MySQL高效获取数据的数据结构。...常见的可以用于建立索引的字段场景: ① 用户id 在订单中的用户id字段上建立索引,根据用户id筛选订单,则会很快查询出用户的订单。...用户一般是在自己的后台查看订单,所以中的其他用户数据与他无关,如果没有建立索引,每次查询都是全扫描,则会很慢。...123456 否则发生类型转换,索引失效,其他类型的字段 比如日期等 也同理 当使用的条件语句,预计结果数量超过全数据的一定比例时,会转为全扫描(mysql一般是30%左右)这就是为什么在建立索引的时候要选择维度...只在维度高的字段上建立索引,否则会使得数据比例过大,转为全扫描。 优先对数据量比较小的字段建立索引,可以使索引文件更小,同时内存中也可以装载更多的索引键。

4.8K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    mysql建立联合索引_mysql之联合索引

    mysql之联合索引测试: 前期准备: 建立联合索引?...,则该索引仅出现在key列表中 rows: 根据统计信息及索引选用情况,大致估算出找到所需的记录所需要读取的行数 Extra: 1、Using filesort : mysql对数据使用一个外部的索引排序...也就是说mysql无法利用索引完成的排序操作成为“文件排序” 2、Using temporary: 使用临时保存中间结果,也就是说mysql在对查询结果排序时使用了临时,常见于order by 和...当type出现all时,表示走的是全扫描没有走索引,效率低下,这时需要对sql进行调优。...测试语句是否使用了索引: 网上说联合索引 test_col1_col2_col3 实际建立了(col1)、(col1,col2)、(col,col2,col3)三个索引

    4.9K30

    MySQL索引建立方式

    MySQL索引建立对于MySQL的高效运行是很重要的,索引可以大大提高MySQL的检索速度。...打个比方,如果合理的设计且使用索引MySQL是一辆兰博基尼的话,那么没有设计和使用索引MySQL就是一个人力三轮车。...创建索引时,你需要确保该索引是应用在 SQL 查询语句的条件(一般作为 WHERE 子句的条件)。 实际上,索引也是一张,该保存了主键与索引字段,并指向实体表的记录。...因为更新时,MySQL不仅要保存数据,还要保存一下索引文件。 建立索引会占用磁盘空间的索引文件。 ---- 普通索引 创建索引 这是最基本的索引,它没有任何限制。...以下实例为在中添加索引mysql> ALTER TABLE testalter_tbl ADD INDEX (c); 你还可以在 ALTER 命令中使用 DROP 子句来删除索引

    2.3K00

    Mysql常用的建立索引规则

    建立索引的规则 建立索引常用的规则如下: 的主键、外键必须有索引; 数据量超过300的应该有索引; 经常与其他进行连接的,在连接字段上应该建立索引; 经常出现在Where子句中的字段,非凡是大的字段...,应该建立索引索引应该建在选择性高的字段上(枚举型字段不建索引); 索引应该建在小字段上,对于大的文本字段甚至超长字段,不要建索引; 复合索引建立需要进行仔细分析;尽量考虑用单字段索引代替: 正确选择复合索引中的主列字段...; 假如既有单字段索引,又有这几个字段上的复合索引,一般可以删除复合索引; 频繁进行数据操作的,不要建立太多的索引; 删除无用的索引,避免对执行计划造成负面影响; ​ 以上是一些普遍的建立索引时的判定依据...一言以蔽之,索引建立必须慎重,对每个索引的必要性都应该经过仔细分析,要有建立的依据。...因为太多的索引与不充分、不正确的索引对性能都毫无益处:在建立的每个索引都会增加存储开销,索引对于插入、删除、更新操作也会增加处理上的开销。 ​

    2.9K10

    mysql查询索引_MySQL查看表索引

    mysql> show index from tblname; mysql> show keys from tblname; · Table 的名称。...· Non_unique 如果索引不能包括重复词,则为0。如果可以,则为1。 · Key_name 索引的名称。 · Seq_in_index 索引中的列序列号,从1开始。...· Collation 列以什么方式存储在索引中。在MySQL中,有值‘A’(升序)或NULL(无分类)。 · Cardinality 索引中唯一值的数目的估计值。...基数根据被存储为整数的统计数据来计数,所以即使对于小型,该值也没有必要是精确的。基数越大,当进行联合时,MySQL使用该索引的机 会就越大。...· Sub_part 如果列只是被部分地编入索引,则为被编入索引的字符的数目。如果整列被编入索引,则为NULL。 · Packed 指示关键字如何被压缩。如果没有被压缩,则为NULL。

    6.8K40

    MySQL建立索引的优点和缺点

    建立索引的优缺点: 为什么要创建索引呢? 这是因为,创建索引可以大大提高系统的性能。...第二、索引需要占物理空间,除了数据占数据空间之外,每一个索引还要占一定的物理空间。如果要建立聚簇索引,那么需要的空间就会更大。...第三、当对表中的数据进行增加、删除和修改的时候,索引也要动态的维护,这样就降低了数据的维护速度。 什么样的字段适合创建索引: 索引建立在数据库中的某些列的上面。...建立索引,一般按照select的where条件来建立,比如: select的条件是where f1 and f2,那么如果我们在字段f1或字段f2上简历索引是没有用的,只有在字段f1和f2上同时建立索引才有用等...(普通索引) mysql> alter table table_name add index index_name ( `column` ) 5.多列索引 (聚簇索引) mysql

    2.2K20

    MySQL索引组织

    MySQL索引组织 今天没怎么学习,简单写下MySQL里面innodb存储引擎下的索引组织吧。...在Innodb存储引擎中,都是根据主键的顺序组织存放的,这种存储方式的称之为索引组织,在innodb存储引擎中,每张都有主键,也就是primary key,如果在创建的时候没有显式的制定主键,...3.当我们的中有多个唯一索引时,innodb存储引擎会选择建时的第一个定义的非空索引作为主键,需要注意的是,主键的选择根据的是定义索引的顺序,而不是建时的顺序。...这张包含a,b,c,d四个列b,c,d三个列上我们都创建了唯一索引,不同的是b的值可以为空,而c,d列都是唯一索引,而且不为空,上面的建表语句没有显式的定义主键,所以innodb存储引擎会帮我们自动选择非空的唯一索引...,可以看出虽然c,d都是非空唯一索引,但是在定义的过程中,unique key (d)比较靠前,所以innodb存储引擎将他作为这个的主键。

    1.4K10

    MYSQL索引覆盖、 索引下推

    每个 INNODB 都会有一个聚簇索引 创建规则如下: * 如果设置了主键,则主键就是聚簇索引 * 如果没有主键,则会默认第一个NOT NULL,且唯一(UNIQUE)的列作为聚簇索引 * 以上都没有...explain 分析: 可通过Extra 是否是Using Index 判断查询是否索引覆盖 如何实现索引覆盖: 将被查询的字段,建立到联合索引里去 哪些场景适合使用索引覆盖来优化SQL 全count...name like '张%' and age = 20; Mysql版本 < 5.6 检索复合索引 idx_name_age 查询出所有 name 包含 “张” 的主键ID 然后通过聚簇索引判断出所有符合...where子句的数据返回 ,此过程需要回 Mysql版本 >= 5.6 检索复合索引 idx_name_age 查询所有 name 包含 “张” 的 且age =20 的数据 直接返回结果集, 无需回...可见 索引下推在非主键索引上的优化,可以有效减少回的次数,大大提升了查询的效率 explain 分析: Using Index Condition 使用了索引下推的表现 end!

    2K30

    MySQL查询索引的方式

    在网上可以查到有两种方式查询索引 show index from tablename SELECT * FROM mysql.innodb_index_stats a WHERE a.database_name...= '数据库名' and a.table_name like '%名%'; 第一种是可行的,问题是在于并不是用SELECT语句,所以就不能和其他的数据一起查询,譬如说 查询结构的时候连同索引一起查询...在网上翻了很多页面都没有找到合适的解决方案,于是我把所有独立数据库用户身份可以查看的全部翻看一遍之后发现。STATICS中是存有索引数据的。...SELECT * FROM INFORMATION_SCHEMA.STATISTICS WHERE TABLE_SCHEMA = basename AND TABLE_NAME = tablename 将索引信息和结构信息一起查看的查询...先将STATISTICS中的数据过滤一遍,再进行合并,两张都要以basename,tablename进行过滤。

    3.3K20

    Mysql索引原理(十五)」维护索引-修复损坏的

    修复损坏的 即使用正确的类型创建了并加上了合适的索引,工作也没有结束:还需要维护索引来确保它们都正常工作。...维护有三个主要的目的:找到并修复损坏的,维护准确的索引统计信息,减少碎片。 损坏(corruption)是很糟糕的事情。对于MyISAM存储引擎,损坏通常是系统崩溃导致的。...其他的引擎也会由于硬件问题、MySQL本身的缺陷或者操作系统的问题导致索引损坏。 损坏的索引会导致查询返回错误的结果或者莫须有的主键冲突等问题,严重时甚至还会导致数据库的崩溃。...CHECK TABLE通常能够找出大多数的索引的错误。...不过,如果损坏的是系统区域,或者是的“行数据”区域,而不是索引,那么上面的办法就没有用了。在这种情况下,可以从备份中恢复,或者尝试从损坏的数据文件中尽可能地恢复数据。

    2.3K20

    MySQL 的回、覆盖索引索引下推

    在研究mysql二级索引的时候,发现Mysql这个操作,往下研究了一下 字面意思,找到索引,回到中找数据 解释一下就是: 先通过索引扫描出数据所在的行,再通过行主键ID 取出数据。...) 索引下推 索引下推(index condition pushdown )简称ICP,在Mysql5.6以后的版本上推出,用于优化回查询; 在不使用ICP的情况下,在使用非主键索引(又叫普通索引或者二级索引..., 然后由存储引擎通过判断索引是否符合MySQL服务器传递的条件,只有当索引符合条件时才会将数据检索出来返回给MySQL服务器 ; 索引条件下推优化可以减少存储引擎查询基础的次数,也可以减少MySQL...索引下推是mysql 5.6优化查询回的功能,在5.6之前都不支持索引下推,笔者用的8.0,则需要先关闭索引下推: set optimizer_switch='index_condition_pushdown...总结: 索引下推功能是mysql 5.6推出优化回的操作,只支持向上兼容,低版本是不支持的; 索引下推优化的只是回次数,扫描行数还是一样的。

    1.3K20

    【说站】mysql有哪些建立索引的方法

    mysql有哪些建立索引的方法 1、最左前缀匹配原则,非常重要的原则,mysql会一直向右匹配直到遇到范围查询(>、 3 and d = 4 如果建立(a,b,c,d)顺序的索引,d是用不到索引的,如果建立(a,b,d,c)的索引则都可以用到,a,b,d的顺序可以任意调整。...2、=和in可以乱序,比如a = 1 and b = 2 and c = 3 建立(a,b,c)索引可以任意顺序,mysql的查询优化器会帮你优化成索引可以识别的形式 3、尽量选择区分度高的列作为索引,...= ’2014-05-29’就不能使用到索引,原因很简单,b+树中存的都是数据中的字段值,但进行检索时,需要把所有元素都应用函数才能比较,显然成本太大。...所以语句应该写成create_time = unix_timestamp(’2014-05-29’); 以上就是mysql建立索引的方法,大家学会后也试着建立索引吧。

    1.4K20

    Mysql索引原理(十六)」维护索引-更新索引统计信息

    MySQL的査询优化器会通过两个API来了解存储引擎的索引值的分布信息,以决定如何使用索引。...MySQL优化器使用的是基于成本的模型,而衡量成本的主要指标就是一个查询需要扫描多少行。如果没有统计信息,或者统计信息不准确,优化器就很有可能做出错误的决定。...在 MySQL5.0和更新的版本中,还可以通过 FORMATION_SCHEMA. STATISTICS很方便地查询到这些信息。...需要注意的是,如果服务器上的库非常多,则从这里获取元数据的速度可能会非常慢,而且会给 MySQL带来额外的压力。 InnodB的统计信息值得深入研究。...InnoDB在打开某些INF0RMATION_SCHEMA,或者使用 SHOW TABLE STATUS和SHOW INDEX,抑或在MySQL客户端开启自动补全功能的时候都会触发索引统计信息的更新。

    2K40

    MySQL查询的索引使用

    项目中一般使用的都是单查询,但是在一些业务场景下,偶尔会选择联查询,一直对联查询时如何使用索引一直感到很好奇。...正好近期项目中遇到一个问题,联查询时,没有建立索引,耗时居然达到了可耻的10分钟,所以趁机了解了一下。...比如:在knowledge的字段update上建立索引idx_time: MySQL [knowledge_base]> alter table knowledge add index idx_time...其他知识点 在建立索引的时候,会遇到Table Metadata Lock的问题,可以先show processlist,找到占用锁的连接,然后kill。...[(none)]> kill 3468722 结论 关联字段一定要添加索引 where条件的索引建立,一定要查看explain,mysql的工作方式经常跟我们想的不一样 增加慢查询日志(dba呢?)

    11.4K21

    MySQL存储过程、索引、分对比

    MySQL存储过程、索引和分是用于提高查询效率的三种不同方法,它们各自对查询效率有不同的影响和应用场景。...这可以减少客户端与服务器之间的通信次数,提高查询效率,特别是对于复杂的事务操作 2.MySQL索引:•影响查询效率: 索引直接影响查询效率。...合适的索引可以大幅提高检索和筛选操作的速度,特别是对于大型。 •适用场景: 索引适用于需要快速查找、排序和筛选数据的场景。常见的索引类型包括单列索引、复合索引和全文索引。...但索引也会占用磁盘空间,对写操作(插入、更新、删除)有一定的开销,因此需要谨慎选择索引。 3.MySQL:•影响查询效率: 分可以显著影响查询效率,特别是对于大型数据集。...同时,也要注意定期监测和维护索引以及分,以确保数据库性能持续优化。

    16320

    使用MySQL Workbench建立数据库,建立新的,向中添加数据

    我用的MySQL数据库,使用MySQL Workbench管理。下面简单介绍一下如何使用MySQL Workbench建立数据库,建立新的,为添加数据。...点击上图中的“加号”图标,新建一个连接, 如上图,先输入数据库的账号密码,帐号默认为root,填好密码后 点击“OK”,连接就建立好了,建立完成后,会出现一个长方形的框框,双击它,出现下图所示页面...一下刚刚建立好的数据库mydatabase,然后再创建,不然会出错,右键点击Tables 然后点击Create new tables ,填写名,以及表列的信息,之后点击 apply ,一张就建完了...Numeric Types”) 出现如下页面 接下来向建好的tb_student中添加数据 右键点击tb_student,再点击select rows limit 1000 在mysql workbench...中向数据库中的中添加数据大致就是这个样子。

    9.8K30
    领券