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

 更新时间:2022年09月27日 08:47:04   作者:孤独王者¥  
这篇文章主要介绍了mysql error 1071: 创建唯一索引时字段长度限制的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

一、先描述一下问题吧

如下创建表时候报错了

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存储过程学习笔记--建立简单的存储过程

    Mysql存储过程学习笔记--建立简单的存储过程

    我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储过程(Stored Procedure)是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,用户通过指定存储过程的名字并给定参数(如果该存储过程带有参数)来调用执行它。
    2014-08-08
  • 关于MySQL日期类型的选择建议

    关于MySQL日期类型的选择建议

    在软件开发中,时间记录是不可或缺的功能,如记录操作时间、交易时间等,通常不建议使用字符串存储日期,因为它占用空间大,并且效率低下,MySQL提供的Datetime和Timestamp是常用的时间存储类型,Datetime没有时区信息,而Timestamp与时区有关
    2024-10-10
  • Mysql、Oracle中常用的多表修改语句总结

    Mysql、Oracle中常用的多表修改语句总结

    这篇文章主要给大家介绍了关于Mysql、Oracle中常用的多表修改语句的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12
  • Mysql中FIND_IN_SET函数的使用及问题

    Mysql中FIND_IN_SET函数的使用及问题

    FIND_IN_SET函数用于返回字符串str在字符串列表str_list中的位置,本文主要介绍了Mysql中FIND_IN_SET函数的使用及问题,具有一定的参考价值,感兴趣的可以了解一下
    2024-07-07
  • mysql8中如何设置sql-mode

    mysql8中如何设置sql-mode

    这篇文章主要介绍了mysql8中如何设置sql-mode问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-07-07
  • MySQL进行JSON查询的详细教程

    MySQL进行JSON查询的详细教程

    在MySQL中,一般会使用特定的 JSON 路径表达式语法来导航和提取 JSON 文档中的数据,本文将为大家详细介绍一下具体的查询方法,希望对大家有所帮助
    2025-03-03
  • MySQL中(JOIN/ORDER BY)语句的查询过程及优化方法

    MySQL中(JOIN/ORDER BY)语句的查询过程及优化方法

    sql语句性能达不到你的要求,执行效率让你忍无可忍,一般会造成很多影响。那么我们如何解决这些问题呢,下面由小编来和大家简单讲下
    2019-05-05
  • MySQL获取二维数组字符串的最后一个值的实现代码

    MySQL获取二维数组字符串的最后一个值的实现代码

    这篇文章主要介绍了MySQL获取二维数组字符串的最后一个值的实现,文中有详细的代码示例供大家参考,对大家的学习或工作有一定的帮助,需要的朋友可以参考下
    2024-04-04
  • SQL 优化

    SQL 优化

    SQL 优化...
    2006-12-12
  • Mysql 5.7 服务下载安装图文教程(经典版)

    Mysql 5.7 服务下载安装图文教程(经典版)

    MySQL 5.7在诸多方面都进行了大幅的改进,主要在于安全性、灵活性、易用性、可用性和性能等几个方面。这篇文章主要介绍了Mysql5.7服务下载安装图文教程(经典版),需要的朋友可以参考下
    2016-09-09

最新评论