wsdydmw 2014-05-13 17:08
浏览 535
已采纳

关于Mysql建表的长度限制

create table Article (
articleID varchar(255) not null,
articleCotent varchar(255),
articleCreateDate datetime,
articleDescription varchar(255),
articlePV integer,
articlePicUrl varchar(255),
articleTitle varchar(60),
articleType varchar(50),
articleUrl varchar(255),
isShowCover bit,
primary key (articleID)
)
执行以上的建表语句,报错Specified key was too long; max key length is 767 bytes
难道必须要修改表的长度才可以吗?
我的MySql是6.0.11版的

  • 写回答

4条回答 默认 最新

  • leehuat 2014-05-13 17:20
    关注

    [code="java"]
    MySQL是限制长度的, 因为你是设置的UTF-8编码,
    articleID 长度是255*4 > 767 的

    mysql官方好像有个说明, 如下
    MySQL has a prefix limitation of 767 bytes in InnoDB, and 1000 bytes in MyISAM. This has never been a problem for me, until I started using UTF-16 as the character set for one of my databases. UTF-16 can use up to 4 bytes per character which means that in an InnoDB table, you can’t have any keys longer than 191 characters. Take this CREATE statement for example:

    CREATE TABLE user (
    id int(11) NOT NULL AUTO_INCREMENT,
    username varchar(32) NOT NULL,
    password varchar(64) NOT NULL,
    email varchar(255) NOT NULL,
    PRIMARY KEY (id),
    UNIQUE KEY UNIQ_8D93D649F85E0677 (username),
    UNIQUE KEY UNIQ_8D93D649E7927C74 (email)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf16 AUTO_INCREMENT=1 ;
    This will fail with an error like Specified key was too long; max key length is 767 bytes, because the UNIQUE INDEX on the email field requires at least 1020 bytes (255 * 4).
    [/code]

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥15 改算法,照着压缩包里边,参考其他代码封装的格式 写到main函数里
  • ¥15 用windows做服务的同志有吗
  • ¥60 求一个简单的网页(标签-安全|关键词-上传)
  • ¥35 lstm时间序列共享单车预测,loss值优化,参数优化算法
  • ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。
  • ¥100 为什么这个恒流源电路不能恒流?
  • ¥15 有偿求跨组件数据流路径图
  • ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值
  • ¥15 我想咨询一下路面纹理三维点云数据处理的一些问题,上传的坐标文件里是怎么对无序点进行编号的,以及xy坐标在处理的时候是进行整体模型分片处理的吗
  • ¥15 一直显示正在等待HID—ISP