首页
学习
活动
专区
工具
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)三个索引

    5K30

    MySQL索引建立方式

    MySQL索引建立对于MySQL高效运行是很重要索引可以大大提高MySQL检索速度。...打个比方,如果合理设计且使用索引MySQL是一辆兰博基尼的话,那么没有设计和使用索引MySQL就是一个人力三轮车。...创建索引时,你需要确保该索引是应用在 SQL 查询语句条件(一般作为 WHERE 子句条件)。 实际上,索引也是一张,该保存了主键与索引字段,并指向实体表记录。...上面都在说使用索引好处,但过多使用索引将会造成滥用。因此索引也会有它缺点:虽然索引大大提高了查询速度,同时却会降低更新速度,如对表进行INSERT、UPDATE和DELETE。...因为更新时,MySQL不仅要保存数据,还要保存一下索引文件。 建立索引会占用磁盘空间索引文件。 ---- 普通索引 创建索引 这是最基本索引,它没有任何限制。

    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建立索引优点和缺点

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

    2.2K20

    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 、覆盖索引索引下推

    在研究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索引原理(十五)」维护索引-修复损坏

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

    2.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索引组织 今天没怎么学习,简单写下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查询索引使用

    正好近期项目中遇到一个问题,联查询时,没有建立索引,耗时居然达到了可耻10分钟,所以趁机了解了一下。...,根据MySQL查询算法Nested-Loop Join,MySQL查询结果集是3张笛卡尔积,所以效率特别低。...比如:在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 临时在我们需要保存一些临时数据时是非常有用。临时只在当前连接可见,当关闭连接时,Mysql会自动删除并释放所有空间。...临时MySQL 3.23版本中添加,如果你MySQL版本低于 3.23版本就无法使用MySQL临时。不过现在一般很少有再使用这么低版本MySQL数据库服务了。...实例 以下展示了使用MySQL 临时简单实例,以下SQL代码可以适用于PHP脚本mysql_query()函数。...如果你退出当前MySQL会话,再使用 SELECT命令来读取原先创建临时数据,那你会发现数据库中没有该存在,因为在你退出时该临时已经被销毁了。...---- 删除MySQL 临时 默认情况下,当你断开与数据库连接后,临时就会自动被销毁。当然你也可以在当前MySQL会话使用 DROP TABLE 命令来手动删除临时

    10.8K11

    MYSQL索引覆盖、 索引下推

    每个 INNODB 都会有一个聚簇索引 创建规则如下: * 如果设置了主键,则主键就是聚簇索引 * 如果没有主键,则会默认第一个NOT NULL,且唯一(UNIQUE)列作为聚簇索引 * 以上都没有...,则会默认创建一个隐藏row_id作为聚簇索引 聚簇索引整体是一个B+树,非叶子节点存放是键值,叶子节点存放是行数据,称之为数据页,这就决定了数据也是聚簇索引一部分,数据页之间是通过一个双向链表来链接...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 数据 直接返回结果集, 无需回

    2K30

    MySQL建立自己哈希索引(书摘备查)

    MySQL中,只有Memory存储引擎支持显式哈希索引,但是可以按照InnoDB使用方式模拟自己哈希索引。这会让你得到某些哈希索引特性,例如很大键也只有很小索引。...想法非常简单:在标准B-Tree索引上创建一个伪哈希索引。它和真正哈希索引不是一回事,因为它还是使用B-Tree索引进行查找。然而,它将会使用键哈希值进行查找,而不是键自身。...通常会按照下面的方式来查找URL: select id from url where url='http://www.mysql.com'; 但是,如果移除url列上索引并给添加一个被索引...//www.mysql.com'); 这种方式很不错,因为MysSQL查询优化器注意到url_crc列上有很小、选择性很高索引,并且它会使用里面的值进行索引查找。...如果有很多行并且crc32()产生了很多冲突,就要实现自己64位哈希函数。要确保自己函数返回整数,而不是字符串。

    2.2K30

    使用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.9K30
    领券