开发者社区 问答 正文

mysql创建数据表,varchar字段报错

mysql创建数据表时发生错误。
字符集:utf-8
补充一下:
mysql版本:Ver 14.14 Distrib 5.1.65, for Win64 (unknown)
错误语句:
9
将varchar中的字符长度,改为200,就可以正常使用了。
这是什么原因?mysql创建长度为2000的varchar字段,应该是没有问题的啊。

展开
收起
落地花开啦 2016-02-15 18:14:57 6090 分享 版权
1 条回答
写回答
取消 提交回答
  • 喜欢技术,喜欢努力的人

    mysql 5.0.3及以前版本varchar类型最大长度是255字符,
    之后版本理论上长度可取值范围是1到65535字节,但实际上不可能取到这么大的值,原因是65535字节是mysql 1行数据占用的长度。所以单个字段是不可能占用这么大的空间的。
    那如果是你设置的值过大,mysql怎么处理呢?
    根据设置的sql_mode不同会有两种情况:
    mysql会把varchar类型转成text类型并产生一个warning;
    MySQL报错;
    所以你需要主意这些。

    2019-07-17 18:43:32
    赞同 展开评论