http://dinglin.iteye.com/blog/914276

http://www.cnblogs.com/fakis/archive/2011/03/07/1976532.html

 
如果某一项中设置的是varchar(50)
那么对英文当然是50
那么对中文呢
utf-8的中文占3个字节
那么,这个varchar(50)是不是只能存16个汉字了?
 
不是这样的,mysql低版本之前是这样的,但是5.0以后就不是了
 
mysql varchar(50)  不管中文 还是英文 都是存50个的,但是一个表中所有varchar字段的总长度跟编码有关,如果是utf-8,那么大概65535/3,如果是gbk,那么大概65535/2.
MySQL5的文档,其中对varchar字段类型这样描述:varchar(m) 变长字符串。M 表示最大列长度。M的范围是0到65,535。(VARCHAR的最大实际长度由最长的行的大小和使用的字符集确定,最大有效长度是65,532字节)。
 
为何会这般变换?真是感觉MySQL的手册做的太不友好了,因为你要仔细的继续往下读才会发现这段描述:MySQL 5.1遵从标准SQL规范,并且不删除VARCHAR值的尾部空格。VARCHAR保存时用一个字节或两个字节长的前缀+数据。如果VARCHAR列声明的长度大于255,长度前缀是两个字节。
 

MySQL中varchar最大长度是多少?这不是一个固定的数字。本文简要说明一下限制规则。

1、限制规则

字段的限制在字段定义的时候有以下规则:

a)  
存储限制

varchar 字段是将实际内容单独存储在聚簇索引之外,实际存储从第二个字节开始,接着要用1到2个字节表示实际长度(长度超过255时需要2个字节),因此最大长度不能超过65535。

b)  
编码长度限制

字符类型若为gbk,每个字符最多占2个字节

字符类型若为utf8,每个字符最多占3个字节

若定义的时候超过上述限制,则varchar字段会被强行转为text类型,并产生warning。

c)  
行长度限制

导致实际应用中varchar长度限制的是一个行定义的长度。 MySQL要求一个行的定义长度不能超过65535。若定义的表长度超过这个值,则提示

ERROR 1118 (42000): Row size too large. The maximum row size for the used table type, not counting BLOBs, is 65535. You have to change some columns to TEXT or BLOBs。

2、计算例子

举两个例说明一下实际长度的计算。

a)                  若一个表只有一个varchar类型,如定义为

create table t4(c varchar(N)) charset=gbk;

则此处N的最大值为(65535-1-2)/2= 32766。

减1的原因是实际行存储从第二个字节开始’;

减2的原因是varchar头部的2个字节表示长度;

除2的原因是字符编码是gbk。

b)                  若一个表定义为

create table t4(c int, c2 char(30), c3 varchar(N)) charset=utf8;

则此处N的最大值为 (65535-1-2-4-30*3)/3=21812

减1和减2与上例相同;

减4的原因是int类型的c占4个字节;

减30*3的原因是char(30)占用90个字节,编码是utf8。

如果被varchar超过上述的b规则,被强转成text类型,则每个字段占用定义长度为11字节,当然这已经不是“varchar”了。

最新文章

  1. MySQL基础之索引
  2. [ASP.NET MVC] ASP.NET Identity登入技术应用
  3. 隐藏ASP.NET站点的HTTP Headers
  4. 再探CSS 中 class 命名规范
  5. hdu 3663 DLX
  6. iOS 父子关系
  7. tortoiseGit的SHH秘钥设置
  8. Java循环语句 while
  9. nginx : TCP代理和负载均衡的stream模块
  10. java web项目修改favicon.ico图标的方式
  11. 开发手机APP的神器 --- ionic
  12. GitHub看板系统(Project)
  13. 在linux中查看进程占用的端口号
  14. Python3从零开始爬取今日头条的新闻【三、滚动到底自动加载】
  15. idea护眼设置
  16. (代码篇)从基础文件IO说起虚拟内存,内存文件映射,零拷贝
  17. Linux服务器---安装bind
  18. [SQL] MSSQL update 语句中的关联
  19. 【leetcode刷题笔记】Majority Element
  20. kahadb设计

热门文章

  1. 记忆化搜索:POJ1088-滑雪(经典的记忆化搜索)
  2. CentOS下的Redis启动脚本
  3. Python 有序字典简介
  4. RxJava Rxandroid retrofit
  5. TCP/IP网络编程之多种I/O函数
  6. AD管理中心
  7. IOS笔记048-数据存储
  8. PageObject模式简介
  9. PHP 命名空间和自动加载
  10. 双网卡只有一个能ping通的解决办法