mysql error 1071: 创建唯一索引时字段长度限制的问题

吾爱主题 阅读:143 2022-11-20 17:37:00 评论:0

一、先描述一下问题吧

如下创建表时候报错了

?
1 2 3 4 5 6 7 8 9 10 11 12 CREATE TABLE `xxx` (    `id` bigint (20) NOT NULL AUTO_INCREMENT,    `sys_code` varchar (255) DEFAULT NULL COMMENT '系统编码' ,    `module_name` varchar (1000) DEFAULT NULL COMMENT '模块名' ,    `call_num` bigint (20) DEFAULT NULL COMMENT '调用次数' ,    `cost_dis` varchar (50) DEFAULT NULL COMMENT '耗时分布' ,    `date_time` varchar (50) DEFAULT NULL COMMENT '日期时间' ,    PRIMARY KEY (`id`),    UNIQUE KEY `sys_code` (`sys_code`, `module_name`, `cost_dis`, `date_time`) ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 > 1071 - Specified key was too long; max key length is 3072 bytes > 时间: 0s

二、显而易见

提示就是长度太长超过了mysql的最大配置。

三、问题和解决方案分析

1、首先考虑是否有方法将mysql这个长度限制调大

查了一下,如下操作:

(1)set global innodb_large_prefix=1; 

?
1 2 3 4 5 6 7 mysql> show variables like 'innodb_large_prefix' ;                                                                                                                                                                                                 + ---------------------+-------+ | Variable_name       | Value | + ---------------------+-------+ | innodb_large_prefix | ON     | + ---------------------+-------+ 1 row in set (0.00 sec)

(2)set global innodb_file_format=BARRACUDA; 

?
1 2 3 4 5 6 7 mysql> show variables like 'innodb_file_format' ;   + --------------------+-----------+ | Variable_name      | Value     | + --------------------+-----------+ | innodb_file_format | Barracuda | + --------------------+-----------+ 1 row in set (0.00 sec)

如果已经设置,还是创建不成功,只能考虑方案二

2、一般来说,唯一索引长度不应该太长

因为mysql会根据这个唯一索引做了一系列的操作,所以

(1)重新审核需求看看这样的唯一索引是否合理,看看能不能减少字段

(2)实在是不行,只能根据具体情况,将字段的长度调整小

比如,上面的例子就是没办法减少字段的,但是我又一定要建立唯一索引,最终,我选择了调整字段长度,将module_name的长度减少到了255,再次创建表,已成功。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。

原文链接:https://blog.csdn.net/qq_30966497/article/details/96316360

可以去百度分享获取分享代码输入这里。
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

【腾讯云】云服务器产品特惠热卖中
搜索
标签列表
    关注我们

    了解等多精彩内容