mysql VARCHAR的最大长度到底是多少

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql VARCHAR的最大长度到底是多少相关的知识,希望对你有一定的参考价值。

  以前一直都认为有两个字节来记录长度(长度小也可以用一个字节记录),所以这个问题当时觉得就挺无聊的不过后来群里有人给了解释,突然才发现原来事情不是这么简单mysql COMPACT格式,每条记录有一个字节来表示NULL字段分布,如果表中有字段允许为空,则最大只能定到65532,如果没有字段允许为空,则那个字节可以节省,最大可以定义到65533,不知道是不是这个原因于是上网看了些资料,又在本地做了些实验,原来vachar的最大长度真的是不定的(根据是否有非空字段来决定)在本地做了下实验,innodb+latin的环境
  复制代码 代码如下:
  -- success
  drop table if exists test;
  create table test(name varchar(65533) not null)engine=innodb DEFAULT CHARSET=latin1-- too large
  drop table if exists test;
  create table test(name varchar(65533))engine=innodb DEFAULT CHARSET=latin1对于第二种情况,允许空字段的时候是不能加到65533的长度的,最大只能到65532,到底应该是引文的那种说法。
  网上也有人做了类似的实验,参考http://stackoverflow.com/questions/8295131/best-practise-for-sql-varchar-column-length复制代码 代码如下:
  name varchar(100) not null will be 1 byte (length) + up to 100 chars (latin1)name varchar(500) not null will be 2 bytes (length) + up to 500 chars (latin1)name varchar(65533) not null will be 2 bytes (length) + up to 65533 chars (latin1)name varchar(65532) will be 2 bytes (length) + up to 65532 chars (latin1) + 1 null byte总结一下,原来mysql的vachar字段的类型虽然最大长度是65535,但是并不是能存这么多数据,最大可以到65533(不允许非空字段的时候),当允许非空字段的时候只能到65532。
  以下是其它网友的补充说明:
  这不是一个固定的数字。本文简要说明一下限制规则。
  strlen 计算字符串长度,一个中文当2字符
  mb_strlen根据它的字符编码模式,统计字符quotcount计算数组中的元素数目或对象中的属性个数复制代码 代码如下:
  <?php
  header(\'Content-Type:text/html;charset=UTF-8\');$string1="谢春业";//定义中文字符变量
  $string2="xcy";//定义英文字符变量
  //直接输出看看他们的长度
  echo strlen($string1);
  echo "</br>";
  echo strlen($string2);
  echo "</br>";
  //用 php 多字节扩展函数 mb_strlen试试看
  echo mb_strlen($string1,\'utf8\');
  echo "</br>";
  echo mb_strlen($string2,\'utf8\');
  echo "</br>";
  ?>
  输出结果是:
  9
  3
  3
  3
  1、限制规则
  字段的限制在字段定义的时候有以下规则:
  a) 存储限制
  varchar 字段是将实际内容单独存储在聚簇索引之外,内容开头用1到2个字节表示实际长度(长度超过255时需要2个字节),因此最大长度不能超过65535。
  b) 编码长度限制
  字符类型若为gbk,每个字符最多占2个字节,最大长度不能超过32766;字符类型若为utf8,每个字符最多占3个字节,最大长度不能超过21845。
  对于英文比较多的论坛 ,使用GBK则每个字符占用2个字节,而使用UTF-8英文却只占一个字节。
  若定义的时候超过上述限制,则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”了。
参考技术A varchar最多能存储65535个字节的数据。

mysql varchar()最大能定义多少,varchar(2000)正确吗

听说最大是varchar(255) ,是这样吗?不能定义超过255的数字吗
varchar(255) 大概可以存多长的字符串

mysql5.0版本以前,varchar()最大能定义255。5.0以上版本支百持65535字节长度,utf8编码下最多支持21843个字符度(不为空)。mysql5.0版本以前,varchar(2000)不正确,5.0以上版本正确。

如果某个数据列里包含许多重复的值,就算为它建立了索引也不会有很好的效果。比如说,如果某个数据列里包含的净是些诸如 “0/1” 或 “Y/N” 等值,就没有必要为它创建一个索引。

扩展资料:

与InnoDB数据表相比,在 InnoDB 数据表上,索引对 InnoDB 数据表的重要性要大得多。在 InnoDB 数据表上,索引不仅会在搜索数据记录时发挥作用,还是数据行级锁定机制的基础。“数据行级锁定”的意思是指在事务操作的执行过程中锁定正在被处理的个别记录。

不让其他用户进行访问。这种锁定将影响到(但不限于)SELECT、LOCKINSHAREMODE、SELECT、FORUPDATE 命令以及 INSERT、UPDATE 和 DELETE 命令。

出于效率方面的考虑,InnoDB 数据表的数据行级锁定实际发生在它们的索引上,而不是数据表自身上。显然,数据行级锁定机制只有在有关的数据表有一个合适的索引可供锁定的时候才能发挥效力。

参考资料来源:百度百科-mySQL



参考技术A

mysql5.0版本以前,varchar()最大能定义255。5.0以上版本支持65535字节长度,utf8编码下最多支持21843个字符(不为空)。mysql5.0版本以前,varchar(2000)不正确,5.0以上版本正确。

VARCHAR(M)是一种比CHAR更加灵活的数据类型,同样用于表示字符数据,但是VARCHAR可以保存可变长度的字符串。其中M代表该数据类型所允许保存的字符串的最大长度,只要长度小于该最大值的字符串都可以被保存在该数据类型中。

扩展资料:

当建立站点时,会发现使用VARCHAR型字段要比CHAR型字段方便的多。使用VARCHAR型字段时,不需要为剪掉数据中多余的空格而操心。

VARCHAR型字段的另一个突出的好处是它可以比CHAR型字段占用更少的内存和硬盘空间。当数据库很大时,这种内存和磁盘空间的节省会变得非常重要.

虽然VARCHAR使用起来较为灵活,但是从整个系统的性能角度来说,CHAR数据类型的处理速度更快,有时甚至可以超出VARCHAR处理速度的50%。因此,用户在设计数据库时应当综合考虑各方面的因素,以求达到最佳的平衡。

参考技术B varchar 在5.03以前长度可以为0~255, 之后是65535
varchar(2000)正确
varchar(255) 大概可以存255字节的字符串, 中英文占位不同, 字符数也不同本回答被提问者采纳
参考技术C varchar255不是这个意思....你真的要去看看基础基础 参考技术D 你不会查看mysql手册吗?每个变量的范围不会查吗?

以上是关于mysql VARCHAR的最大长度到底是多少的主要内容,如果未能解决你的问题,请参考以下文章

mysql varchar最大是多少?

mysql varchar 最大可以设置多少

mysql varchar 最大可以设定多少

mysql varchar()最大能定义多少,varchar(2000)正确吗

MySQL的VARCHAR最大值是多少

Mysql一个表中 最多能存多少文字? 一列中varchar最大值允许多少?