iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >mysql error 1071: 创建唯一索引时字段长度限制的问题
  • 915
分享到

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

2024-04-02 19:04:59 915人浏览 八月长安
摘要

目录一、先描述一下问题吧二、显而易见三、问题和解决方案分析一、先描述一下问题吧 如下创建表时候报错了 CREATE TABLE `xxx` ( `id` bigint(20) NOT NULL AUTO_INCREME

一、先描述一下问题吧

如下创建表时候报错了

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,再次创建表,已成功。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

您可能感兴趣的文档:

--结束END--

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

本文链接: https://www.lsjlt.com/news/34222.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作