日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

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

發布時間:2025/3/11 数据库 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 oracle varchar默认长度_面试官:如何精确计算mysql数据库索引长度? 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

概述

我們知道MySQL Innodb 對于索引長度的限制為 767 字節,并且UTF8mb4字符集是4字節字符集,則 767字節 / 4字節每字符 = 191字符(默認索引最大長度),所以在varchar(255)或char(255) 類型字段上創建索引會失敗,提示最大索引長度為767字節。

那么怎么去計算mysql數據庫索引長度呢?


實驗測試

先看網上一道題目,針對表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);

2、分別執行這兩條語句

mysql> explain select * from t where a=1 and c=1;mysql> explain select * from t where a=1 and b=1;

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的呢?

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);

6、計算key_len

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

分析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方面的內容,感興趣的朋友可以關注一下~

總結

以上是生活随笔為你收集整理的oracle varchar默认长度_面试官:如何精确计算mysql数据库索引长度?的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: av夜夜 | 欧美日韩资源 | 天天操天天操天天干 | 夜夜嗨一区二区 | av在线黄 | 老外一级黄色片 | 制服师生在线 | 中文字幕伦理 | xxxxx黄色片 噜噜噜噜噜色 | 久久神马影院 | 麻豆自拍视频 | 四虎国产成人精品免费一女五男 | 99精品在线免费观看 | caopor在线| 天天做天天射 | 牛夜精品久久久久久久99黑人 | 久久精品久久久久久久 | 美女131爽爽爽做爰视频 | 国产免费av一区二区三区 | 超碰人人网| 日韩欧美在线视频播放 | 少妇天天干| 欧美日韩五区 | 激情丁香| 两性动态视频 | 国产人成在线观看 | 一及黄色大片 | 天堂二区 | 免费看毛片网站 | 黄色仓库av | 亚洲在线视频播放 | 成 人 免费 黄 色 | 日本精品一区二区三区四区 | 国产中文字幕在线视频 | 国产真实交换夫妇视频 | 无套内谢少妇露脸 | 女人黄色片 | 久久人妻少妇嫩草av无码专区 | 精品久久久久久久久久岛国gif | 日大逼 | 日韩免费观看视频 | 人人妻人人藻人人爽欧美一区 | 超碰在线视屏 | 亚洲成a人片 | 国产又大又黑又粗 | 欧美成人精品欧美一级乱黄 | 国产欧美日韩在线观看 | 久久93| 国产夫妻性生活视频 | 伊人久久97 | 乱淫的女高中暑假调教h | 亚洲av永久无码精品一区二区国产 | 韩国美女被c | 九九热在线视频播放 | 日韩专区视频 | 五月婷婷六月香 | 国产视频三级 | 精品理论片 | 中文字幕一区二区三区又粗 | 欧美色xxxxx| 欧美七区 | a级黄色网址 | 欧洲成人在线观看 | 91久久久久久久 | 黑人干亚洲女 | 国产91视频播放 | av毛片在线免费观看 | 青青草草 | 亚洲精选中文字幕 | 国产成人精品在线观看 | 亚洲激情在线视频 | 女人的毛片| 日本免费网址 | 成人黄色电影在线 | 一级黄色在线播放 | 狠狠躁18三区二区一区传媒剧情 | 无码国精品一区二区免费蜜桃 | 风韵多水的老熟妇 | 亚洲婷婷在线观看 | 越南性xxxx精品hd | 欧美日韩精品电影 | 中文字幕在线免费观看 | av资源网站| 国产一区二区精华 | 一级片视频播放 | 成人91视频 | 三上悠亚在线一区二区 | 蜜桃视频色 | 伊人啪啪 | 欧美真人性野外做爰 | 国产呦小j女精品视频 | 日韩激情一区二区三区 | 国产91看片 | 91国产精品 | 在线观看不卡的av | 99久国产 | 亚州av片| 精品国产欧美 | 老司机午夜性大片 |