返回顶部
首页 > 资讯 > 数据库 >Innodb关键特性之Adaptive Hash Index
  • 515
分享到

Innodb关键特性之Adaptive Hash Index

2024-04-02 19:04:59 515人浏览 独家记忆
摘要

      众所周知,InnoDB使用的索引结构是B+树,但其实它还支持另一种索引:自适应哈希索引。 哈希表是数组+链表的形式。通过哈希函数计算每个节点数据中键所对应的哈希

      众所周知,InnoDB使用的索引结构是B+树,但其实它还支持另一种索引:自适应哈希索引。

哈希表是数组+链表的形式。通过哈希函数计算每个节点数据中键所对应的哈希桶位置,如果出现哈希冲突,就使用拉链法来解决。更多内容可以参考  百度百科-哈希表

Innodb关键特性之Adaptive Hash Index

      从以上可以知道,哈希表查找最优情况下是查找一次.而InnoDB使用的是B+树,最优情况下的查找次数根据层数决定。因此为了提高查询效率,InnoDB便允许使用自适应哈希来提高性能。

可以通过参数 innodb_adaptive_hash_index 来决定是否开启。阿里云默认是关闭的。

Mysql>show variables like '%innodb_adaptive_hash_index%'
+----------------------------------+-----------------+
| Variable_name                    | Value           |
+----------------------------------+-----------------+
| innodb_adaptive_hash_index       | OFF             |
| innodb_adaptive_hash_index_parts | 8               |
+----------------------------------+-----------------+

         存储引擎会自动对个索引页上的查询进行监控,如果能够通过使用自适应哈希索引来提高查询效率,其便会自动创建自适应哈希索引,不需要开发人员或运维人员进行任何设置操作。

      自适应哈希索引是对innodb的缓冲池的B+树页进行创建,不是对整张表创建,因此速度很快。

      可以通过查看innodb的status来查看自适应哈希索引的使用情况。

INSERT BUFFER AND ADAPTIVE HASH INDEX
-------------------------------------
Ibuf: size 1, free list len 6236, seg size 6238, 50367801 merges
merged operations:
 insert 78512159, delete mark 0, delete 0
discarded operations:
 insert 0, delete mark 0, delete 0
Hash table size 13148407, node heap has 0 buffer(s)
Hash table size 13148407, node heap has 0 buffer(s)
Hash table size 13148407, node heap has 0 buffer(s)
Hash table size 13148407, node heap has 0 buffer(s)
Hash table size 13148407, node heap has 0 buffer(s)
Hash table size 13148407, node heap has 0 buffer(s)
Hash table size 13148407, node heap has 0 buffer(s)
Hash table size 13148407, node heap has 0 buffer(s)
0.00 hash searches/s, 67793.48 non-hash searches/s

可以看到自适应哈希索引的大小,以及使用情况。

注意: 从哈希表的特性来看,自适应哈希索引只能用于等值查询,范围或者大小是不允许的。

等值查询: select * from xx where name = "xxx";

您可能感兴趣的文档:

--结束END--

本文标题: Innodb关键特性之Adaptive Hash Index

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

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

猜你喜欢
  • Innodb关键特性之Adaptive Hash Index
          众所周知,InnoDB使用的索引结构是B+树,但其实它还支持另一种索引:自适应哈希索引。 哈希表是数组+链表的形式。通过哈希函数计算每个节点数据中键所对应的哈希...
    99+
    2024-04-02
  • InnoDB关键特性之自适应hash索引
    一、索引的资源消耗分析 1、索引三大特点   1、小:只在一个到多个列建立索引   2、有序:可以快速定位终点   3、有棵树:可以定位起点,树高一般小于等于3 ...
    99+
    2024-04-02
  • Innodb关键特性之什么是doublewrite
    本篇内容介绍了“Innodb关键特性之什么是doublewrite”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有...
    99+
    2024-04-02
  • Innodb关键特性之什么是Insert Buffer
    本篇内容介绍了“Innodb关键特性之什么是Insert Buffer”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够...
    99+
    2024-04-02
  • Innodb关键特性之什么是异步IO
    这篇文章主要介绍“Innodb关键特性之什么是异步IO”,在日常操作中,相信很多人在Innodb关键特性之什么是异步IO问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Inno...
    99+
    2024-04-02
  • MySQL Innodb关键特性之插入缓冲(insert buffer)
    什么是insert buffer?    插入缓冲,也称之为insert buffer,它是innodb存储引擎的关键特性之一,我们经常会理解插入缓冲时缓冲池的一个部分,这样的理解是片面的,ins...
    99+
    2022-05-27
    MySQL Innodb Innodb 插入缓冲 Innodb insert buffer
  • Innodb关键特性之怎么刷新邻接页
    本篇内容介绍了“Innodb关键特性之怎么刷新邻接页”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1、工作...
    99+
    2024-04-02
  • Innodb关键特性之怎么实现启动、关闭和恢复
    这篇文章主要讲解了“Innodb关键特性之怎么实现启动、关闭和恢复”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Innodb关键特性之怎么实现启动、关闭和恢...
    99+
    2024-04-02
  • 11gR2 新特性之(一)Adaptive Cursor Sharing(ACS)
    11gR2 新特性之(一)Adaptive Cursor Sharing(ACS) http://www.killdb.com/2011/06/19/11gr2-%e6%96%b0%e7%89%b9%e6%...
    99+
    2024-04-02
  • innodb新特性之buffer pool预热
    背景 innodb buffer pool做为innodb最重要的缓存,其缓存命中率的高低会直接影响数据库的性能。因此在数据库发生变更,比如重启、主备切换实例迁移等等,innodb buffer pool ...
    99+
    2024-04-02
  • Mycat关键特性介绍
    关键特性: 支持SQL92标准 支持MySQL、Oracle、DB2、SQL Server、PostgreSQL等DB的常见SQL语法 遵守Mysql原生协议,跨语言,跨平台,跨数据库的通用中间件代理。 ...
    99+
    2024-04-02
  • GreatDB关键技术特性
    北京万里开源软件有限公司自主研发的GreatDB数据库是国内领先的国产数据库,自2012年开始研发,客户案例遍布金融、能源、电信、政府等各行业,产品以“极致稳定、极致性能、极致易用”为核心目标,满足客户核心...
    99+
    2024-04-02
  • MySQL 8.0 新特性之哈希连接(Hash Join)
    MySQL 开发组于 2019 年 10 月 14 日 正式发布了 MySQL 8.0.18 GA 版本,带来了一些新特性和增强功能。其中最引人注目的莫过于多表连接查询支持 hash join 方式了。我们...
    99+
    2024-04-02
  • InnoDB 性能调优 – 优化 MySQL 数据库的关键 InnoDB 变量
    InnoDB 是 MySQL 的核心存储引擎,即使在最具挑战性的生产环境中也以其可靠性和性能而闻名。要真正优化 InnoDB,您需要深入了解各种系统变量以及它们如何与您独特的服务器设置...
    99+
    2024-07-10
    mysql 数据访问 敏感数据 数据丢失
  • Oracle 12c新特性之——TABLE ACCESS BY INDEX ROWID BATCHED
    Oracle12c开始,我们在获取SQL语句的执行计划时,也会经常看到"TABLE ACCESS BY INDEX ROWID BATCHED"操作,那么,这个操作到底是什么意思呢?有什么作用呢?下面我...
    99+
    2024-04-02
  • PHP关键特性之命名空间的示例分析
    这篇文章主要介绍PHP关键特性之命名空间的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!你知道命名空间主要是为了解决代码中类和函数可能存在冲突的问题的吗?而这个特性其他语言一早就有,PHP则是姗姗来迟,它的出...
    99+
    2023-06-15
  • Java的关键特性有哪些
    本篇内容主要讲解“Java的关键特性有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java的关键特性有哪些”吧!Document the Java: Sun Microsystems 公司...
    99+
    2023-06-03
  • Java volatile关键字特性讲解下篇
    目录一、概述二、特性详解一、概述 关键字volatile虽然增加了实例变量在多个线程之间的可见性,但它却不具备同步性,那么也就不具备原子性。 二、特性详解 原子性是指一个线程的操作是...
    99+
    2022-12-12
    Java volatile Java volatile关键字
  • Java volatile关键字的特性是什么
    这篇文章主要讲解了“Java volatile关键字的特性是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java volatile关键字的特性是什么”吧!一、概述v...
    99+
    2023-07-04
  • 基于JavaScriptES新特性let与const关键字
    目录1.let关键字 1.1基本用法 1.2不存在变量提升 1.3暂时性死区 1.4不允许重复声明 1.5与函数的关系 2.const关键字 2.1基础用法 1.let关键字 1....
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作