mysql 字符串类型问题
菜鸟刚学mysql~~~~createtablemix(avarchar(65532)notnull,btingyintnotnull)charactersetlatin...
菜鸟刚学mysql~~~~
create table mix(
a varchar(65532) not null,
b tingyint notnull
)character set latin1;
提问:b tingint为什么会影响到a varchar的取值范围?a 和b不是不同字段吗?为什么会共用varchar的字节?
a) 存储限制
varchar 字段是将实际内容单独存储在聚簇索引之外,内容开头用1到2个字节表示实际长度(长度超过255时需要2个字节),因此最大长度不能超过65535。
b) 编码长度限制
字符类型若为gbk,每个字符最多占2个字节,最大长度不能超过32766;
字符类型若为utf8,每个字符最多占3个字节,最大长度不能超过21845。
求大神求大神求大神-- 展开
create table mix(
a varchar(65532) not null,
b tingyint notnull
)character set latin1;
提问:b tingint为什么会影响到a varchar的取值范围?a 和b不是不同字段吗?为什么会共用varchar的字节?
a) 存储限制
varchar 字段是将实际内容单独存储在聚簇索引之外,内容开头用1到2个字节表示实际长度(长度超过255时需要2个字节),因此最大长度不能超过65535。
b) 编码长度限制
字符类型若为gbk,每个字符最多占2个字节,最大长度不能超过32766;
字符类型若为utf8,每个字符最多占3个字节,最大长度不能超过21845。
求大神求大神求大神-- 展开
1个回答
展开全部
1 注意事项一,varchar 同时受字符集、行长度的影响。
在使用多字节编码的字符集时,最大实际是 65535/编码字节长度,如使用gbk时,最大就是32767;而utf8编码字节长度为3,因此最大长度不能超过21845。
此外,varchar 的最大长度也受限于行长度,行长度即所有列的长度和,行长度限制为65535字节;因此,如有很多列,实际可定义的列长度会受影响。
2 注意事项二,当出现注意事项一中的情况下,可使用text类型代替varchar。
3 注意事项三,由于mysql在定义varchar时,会自动将大于65535或gbk的32767的类型转化为mediumtext,因此不要误认为varchar可以取大于这个长度的值。
使用 show create table ... 来查看便知;
有时,由于自动转化的原因,会出现一些很奇怪的现象:
create table c (a varchar(20000), a2 varchar(20000), a3 varchar(40000)) ; --会失败,提示超过行长度
create table c (a varchar(20000), a2 varchar(40000), a3 varchar(40000)) ; --则会成功,后两列均转化为 mediumtext
在使用多字节编码的字符集时,最大实际是 65535/编码字节长度,如使用gbk时,最大就是32767;而utf8编码字节长度为3,因此最大长度不能超过21845。
此外,varchar 的最大长度也受限于行长度,行长度即所有列的长度和,行长度限制为65535字节;因此,如有很多列,实际可定义的列长度会受影响。
2 注意事项二,当出现注意事项一中的情况下,可使用text类型代替varchar。
3 注意事项三,由于mysql在定义varchar时,会自动将大于65535或gbk的32767的类型转化为mediumtext,因此不要误认为varchar可以取大于这个长度的值。
使用 show create table ... 来查看便知;
有时,由于自动转化的原因,会出现一些很奇怪的现象:
create table c (a varchar(20000), a2 varchar(20000), a3 varchar(40000)) ; --会失败,提示超过行长度
create table c (a varchar(20000), a2 varchar(40000), a3 varchar(40000)) ; --则会成功,后两列均转化为 mediumtext
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询