一、先描写一下问题吧
以下创建表时候报错了
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;
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;
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,再次创建表,已成功。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。
文章来源:丸子建站
文章标题:mysql error 1071: 创建唯一索引时字段长度限制的问题
https://www.wanzijz.com/view/61311.html