码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【HBZ分享】Mysql的InnoDB原理


    没有配置主键时Mysql的InnoDB是如何做的?

    1. Mysql会使用自带的rowid作为主键

    InnoDB的底层数据结构是什么?

    1. B+Tree

    BTree的特点(MyISAM)

    1. 非聚集索引,即【索引】和【对应数据】是分开的两个文件。
    2. 找到对应数据后,节点的key下面带有数据的data,是一个16进制的,这个data就标识着该key的内容在数据文件中对应的位置,然后会拿着这个16进制的data去数据文件找对应的数据

    B+Tree的特点(InnoDB)

    1. 聚集索引,即【索引】和【对应数据】是在一起的,在一个文件中
    2. 通过索引找到对应key后,这条数据的内容其实和key是在一起的,直接取回数据即可,无需再拿着data去另一个文件找,这就是有点
    3. B+Tree的叶子节点的key,即主键id是有序的,从小到达排列的,也就是对范围查找又很大的好处
    4. 范围查找,比如id > 15, 即叶子key=15后面的所有数据都是要的,因为id是由顺序排列的,15后面的节点,一定都是大于15的

    为什么InnoDB引擎需要主键,并且推荐使用整数?

    1. B+Tree底层可能会做一些值比较大小的操作,这个时候整数就突显优势了,比如id > 15.
    2. 如果不使用整数,而用uuid,如果后期用到范围查询,那只能通过时间了,不能通过主键id
  • 相关阅读:
    Spark入门
    若依和芋道
    金仓数据库 KingbaseGIS 使用手册(8.12. 栅格运算符、8.13. 栅格和栅格波段空间关系函数)
    P1719 最大加权矩形
    React中JSX语法入门
    Pytorch 快速参数权重初始化
    Java基础(二十四):MySQL
    python绘制立体玫瑰花
    学Java可以从事什么工作 就业前景怎么样
    站长工具综合查询 iis7站长之家SEO综合查询工具
  • 原文地址:https://blog.csdn.net/a645293829/article/details/125507979
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号