首页 > 数据库 > mysql教程 > MySQL varchar计算:求列的数目和计算N的最大值_MySQL

MySQL varchar计算:求列的数目和计算N的最大值_MySQL

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
发布: 2016-06-01 13:28:48
原创
1322 人浏览过

bitsCN.com

MySQL varchar计算:求列的数目和计算N的最大值

 

有道面试题:若一张表中只有一个字段VARCHAR(N)类型,utf8编码,则N最大值为多少?

先明白计算的一些规则限制

 

① 存储限制

    需要额外地在长度列表上存放实际的字符长度:小于255为1个字节,大于255则要2个字节

② 编码限制

    gbk:每个字符最多占用2个字节

    utf8:每个字符最多占用3个字节

③ 长度限制

    MySQL定义行的长度不能超过65535,这个限制了列的数目,比如char(255) utf8

    那么列的数目最多有65535/(255*3)=85,列的数目可以从这里得到依据

   

行长度计算公式如下:

row length = 1                   + (sum of column lengths)                   + (number of NULL columns + delete_flag + 7)/8                   + (number of variable-length columns)
登录后复制

 

① 对于MyISAM,需要额外1个位来记录值是否为NULL;对于InnoDB,没有区别

② 对于row_format为fixed,delete_flag为1;对于row_format=dynamic,delete_flag为0

 

根据这个公式,我们便能够解答开头N的最大值:(65535-1-2)/3

减1是因为实际存储从第2个字节开始

减2则因为要在列表长度存储实际字符长度

除3是因为utf8编码限制

bitsCN.com
相关标签:
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
php 计算数组最大最小值 大神进
来自于 1970-01-01 08:00:00
0
0
0
objective-c - 如何在栈区获取最大值最小值?
来自于 1970-01-01 08:00:00
0
0
0
javascript 最大数值
来自于 1970-01-01 08:00:00
0
0
0
php max_input_vars 最大值?
来自于 1970-01-01 08:00:00
0
0
0
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板