oracle varchar默认长度_面试官:如何精确计算mysql数据库索引长度?

概述

我们知道MySQL Innodb 对于索引长度的限制为 767 字节,并且UTF8mb4字符集是4字节字符集,则 767字节 / 4字节每字符 = 191字符(默认索引最大长度),所以在varchar(255)或char(255) 类型字段上创建索引会失败,提示最大索引长度为767字节。

那么怎么去计算mysql数据库索引长度呢?

745e5f1dd6d297f5db54773156b03c88.gif

实验测试

先看网上一道题目,针对表t,包含了三个字段a、b、c,假设其默认值都非空,现创建组合索引index(a,b,c) 分析select * from t where a=1 and c=1 和select * from t where a=1 and b=1区别?

1、创建表

create table t(a int(5) not null,b int(5) not null,c int(2) not null);create index idx_all on t(a,b,c);
82d214d11e386db0afc7f2f9aa27e88c.png

2、分别执行这两条语句

mysql> explain select * from t where a=1 and c=1;mysql> explain select * from t where a=1 and b=1;
6522c732556cb4cb62cd28043271480c.png

3、思路

这里可以发现,前面两个的区别主要是在于key_len上,我的理解是:

将组合索引想成书的一级目录、二级目录、三级目录,如index(a,b,c),相当于a是一级目录,b是一级目录下的二级目录,c是二级目录下的三级目录。要使用某一目录,必须先使用其上级目录,除了一级目录除外。

所以

where a=1 and c=1只使用了一级目录,c在三级目录,没有使用二级目录,那么三级目录就没法使用

where a=1 and b=1只使用了一级目录、二级目录。

于是第二条查询的key_len更大。

但是,具体key_len怎么计算的,上面怎样计算出是4和8的呢?

9e45312409bae3e94396a2c97c272800.gif

4、key_len的计算.

1.所有的索引字段,如果没有设置not null,则需要加一个字节。

2.定长字段,int占四个字节、date占三个字节、char(n)占n个字符。

3.对于变成字段varchar(n),则有n个字符+两个字节。

4.不同的字符集,一个字符占用的字节数不同。latin1编码的,一个字符占用一个字节,gbk编码的,一个字符占用两个字节,utf8编码的,一个字符占用三个字节。

5.索引长度 char()、varchar()索引长度的计算公式:

(Character Set:utf8mb4=4,utf8=3,gbk=2,latin1=1) * 列长度 + 1(允许null) + 2(变长列)

所以从上面可以得出

where a=1 and c=1而言,key_len=4

where a=1 and b=1而言,key_len=4+4=8

5、创建新的测试表t2

创建一个t2表,数据结构如下

create table t2(id int(5) not null,name varchar(5) not null) engine=innodb default charset=latin1;create index idx_2 on t2(id,name);
a8269109328b517fa7efaab739382661.png

6、计算key_len

explain select * from t2 where name="001" and id=1;
1aad51c593f74cd636d4bb46fb134980.png

分析key_len=4+5*1+2=11,因为字段都是not null,int类型4个字节,varchar(5) 占用5个字符+2个字节,latin1编码的表一个字符占1个字节,故varchar(5) 占用7个字节。


总结

因为MySQL具有查询优化器,所以对where a=1 and c=1类型的查询,字段顺序没有任何影响,查询优化器会自动优化。where c=1 and a=1会被优化成where a=1 and c=1,但是建议还是使用where a=1 and c=1吧,便于理解以及查询缓冲。

后面会分享更多devops和DBA方面的内容,感兴趣的朋友可以关注一下~

68b80da4017f9abe83c739c15478e33e.gif

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/551812.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

android things 系统镜像文件_开始菜单搬家!Win 10X 系统 UI 全部重做,明年初就能用上...

不知道老伙计们还记不记得,小淙曾经报道过三次,关于微软新系统 Windows 10X 的消息。当时很多老伙计感觉太遥远,或者觉得它难以激起波澜。但现在看来微软布局已久,是铁了心要搞新系统了。因为 Windows 10X 系统已经准备好交付&…

通达信公式大全_通达信MACD金叉的选股公式大全

公式来源于网络&#xff0c;我只是用其中一个&#xff0c;一起复制来了&#xff0c;有需要的自取吧。1、0轴上方第一次金叉选股公式&#xff1a;DIFF:EMA(CLOSE,12) - EMA(CLOSE,26);DEA : EMA(DIFF,9);MACD : 2*(DIFF-DEA);xg:cross(diff,dea) and dea>-1.0 and dea<0.5…

mysql 时间差_后端从mysql取值返回0时区时间数据的问题

近日搞一个B/S项目&#xff0c;前端页面时间字段总是显示格林威冶时间&#xff0c;也就是0时区的时间&#xff0c;比北京时间差了8个小时。打开后台的数据库&#xff0c;在workbench中查询&#xff0c;结果显示的时间格式正常&#xff0c;为当前北京时间。该时间字段是在往数据…

abap视图字段限制_【第八章】视图

上一级目录&#xff1a;Mosh_完全掌握SQL课程_学习笔记 其它相关&#xff1a;数据概要【第八章】视图Views (时长18分钟)1. 创建视图Creating Views (5:36)小结就是创建虚拟表&#xff0c;自动化一些重复性的查询模块&#xff0c;简化各种复杂操作&#xff08;包括复杂的子查询…

生活质量衡量系统_数据质量与数据质量八个维度指标

数据质量与数据质量八个维度指标数据的质量直接影响着数据的价值&#xff0c;并且直接影响着数据分析的结果以及我们以此做出的决策的质量。质量不高的数据不仅仅是数据本身的问题&#xff0c;还会影响着企业经营管理决策&#xff1b;错误的数据还不如没有数据&#xff0c;因为…

linux的内置的账户_6 款面向 Linux 用户的开源绘图应用程序

既然你是一名 Linux 用户&#xff0c;为什么不关注一下开源绘图应用程序呢&#xff1f;-- Ankush Das(作者)小时候&#xff0c;当我开始使用计算机(在 Windows XP 中)时&#xff0c;我最喜欢的应用程序是微软的“画图”。我能在它上面涂鸦数个小时。出乎意料&#xff0c;孩子们…

ieda ts文件报错_使用TS开发微信小程序(1):环境搭建——VSCode+TS

前言现在接到小程序需要改版的需求&#xff0c;由于使用Ionic的经验&#xff0c;希望以后能够统一开发语言降低开发成本&#xff0c;所以想使用TypeScript进行开发。开发前准备工作先是看官网&#xff0c;在微信小程序的官方开发文档中找到TypeScript相关的支持介绍。微信官网描…

cad统计多条线段总长度插件_超级实用CAD技巧应用汇总!技巧大全、插件合集、快捷键合集等...

超级实用CAD技巧应用汇总&#xff01;技巧大全、插件合集、快捷键合集等各位朋友&#xff0c;CAD福利来啦&#xff01;超级实用CAD技巧应用汇总&#xff0c;千万不能错过&#xff01;有技巧大全、插件合集、快捷键合集、字体大全、常用图库大全、常见问题及解决办法、版本转换&…

局部放大_Origin教程|巧用ZOOM功能做数据对比和快速绘制局部放大图

微信公众号&#xff1a;有宝物的柜子编辑&#xff1a;落水无波2020-06-28 原创有时候在分析一些数据时&#xff0c;既需要观察整体又需要局部观测&#xff0c;那么怎么才能做到同时查看呢&#xff0c;就类似上面这样。这样就很容易的去发现有没有峰位偏移&#xff0c;同时查看与…

操作多台_一支热电偶能否连接多台显示仪表

一支热电偶能否连接多台显示仪表&#xff0c;这个问题常有人提出&#xff0c;因为随着DCS系统的应用及对管理工作的要求&#xff0c;需要对一个信号在多处显示也是常有的事。一支热电偶能否连接多台显示仪表或DCS系统板卡&#xff0c;连接后能否保证测量精度&#xff0c;这是人…

个性签名设计软件_佩服!我用Python设计了一个签名软件

临近年末&#xff0c;大家都忙着签发礼品&#xff0c;写的一手好的签名&#xff0c;会让大家更有成就感&#xff0c;今天&#xff0c;小安就带领大家来设计一个基于tkinter爬虫的签名设计软件&#xff0c;方便大家设计签名。要设计这款软件&#xff0c;就需要了解tkinter与爬虫…

华为硬件工程师社招机考题库_中级会计机考你了解吗?机考操作常见八大问题速看...

中级会计考试采用无纸化机考的形式&#xff0c;考生们在备考时要多熟悉机考操作&#xff0c;为了帮助考生提前了解无纸化机考&#xff0c;东奥小编整理了一些机考的常见问题&#xff0c;希望能够帮助到大家&#xff01;一、参加无纸化考试的考生允许带计算器入场吗&#xff1f;…

网站攻击软件_佳能遭严重勒索软件攻击,10TB的数据被窃取,大量服务宕机

佳能遭严重勒索软件攻击&#xff0c;10TB的数据被窃取&#xff0c;大量服务宕机Garmin 遭勒索攻击的风波未平&#xff0c;近日&#xff0c;佳能又遭受了勒索软件攻击&#xff0c;攻击除了让佳能的一些网站宕机外&#xff0c;据说还导致佳能服务器中高达 10TB 的数据被盗。 影响…

js datagrid新增一行_Django接口新增页面编写_2(十五)

做一个好看的页面真的是一件困难的事情&#xff0c;所以还是遵循复制后修改的原则&#xff0c;首先是借鉴httpbin页面的方式进行块状展开。块状从模版中找到类似的html代码&#xff1a;块状我们可以看到一下它的动态效果&#xff0c;可以自主的展开和合拢。蛮符合我们的要求的动…

uboot下nand flash读写方法_鸿蒙HarmonyOS烧录方法总结

1.烧录工具理解HarmonyOS驱动框架&#xff0c;用户态APP和内核态驱动之间的通信机制。HarmonyOS烧录使用的海思自研的烧录工具Hitool&#xff0c;使用起来相对来说比较简单。整体界面如图所示&#xff1a;2. 烧录内容烧录内容主要分为两部分&#xff0c;一部分是引导文件fastbo…

合成孔径雷达_合成孔径雷达(SAR)基础:汇总

详细分析&#xff1a;合成孔径雷达成像技术对雷达成像的几点补充消费级小型无人机的合成孔径雷达成像我国微型合成孔径雷达发展现状对比三种天基系统&#xff0c;看SAR成像模式星载SAR详解&#xff1a;“高分三号”微波遥感卫星机载Pol-InSAR系统&#xff0c;新体制SAR成像结果…

将命令结果赋给变量_不得不了解的quot;变量quot;(2)—— 变量的赋值

祝大家圣诞快乐&#xff0c;今天晚上下班后去滑雪&#xff0c;第一次尝试单板&#xff0c;看着别玩玩得挺酷的&#xff0c;自己耍起来摔得差点骨头没散架&#xff01;愈挫愈勇啦&#xff0c;就像我们学习脚本一样&#xff0c;要坚持学下去练下去才能熟练&#xff0c;才能日后装…

vscode代码库登录配置_VSCode 配置 Sonar Lint支持代码检查提效

安装SonarQube插件在VScode的扩展里面&#xff0c;安装SonarQube support for Visual Studio Code extension&#xff0c; 在安装了 SonarQube 之后&#xff0c;使用打开 VSCode 命令搜索功能&#xff0c;输入 Sonar&#xff0c;搜索结果如下&#xff1a;sonar lint 全局配置文…

数据立方体_立方体纹理

立方体纹理就是包含6个2D纹理的纹理.6个纹理有序排列在立方体的6个面.其可以通过方向向量采样立方体纹理上的纹素.创建立方体贴图跟创建2D贴图一样,但是绑定到GL_TEXTURE_CUBE_MAP上.glGenTextures(1, &CubeMapID); glBindTexture(GL_TEXTURE_CUBE_MAP, CubeMapID);立方体纹…

华为官方强制线刷工具_一加8/8Pro 线刷救砖

9008线刷是高通平台设备底层的刷机模式&#xff0c;是降级救砖必备良品&#xff0c;有了它&#xff0c;放心刷不想自己动手或遇到困难&#xff0c;可在后台回复: 远程刷机如果你是新手&#xff0c;要9008降级或者救砖&#xff0c;请先准备好充足的时间和良好的心态&#xff0c;…