内容简介:使用mariadb创建数据表,遇到了这个是提示(Specified key was too long; max key length is 1000 bytes)。如果直接执行出现的错误是索引的长度限制是1000, 因为
使用mariadb创建数据表,遇到了这个是提示(Specified key was too long; max key length is 1000 bytes)。 原因是索引键太长了,超过了1000 ,出现这样的情况,调整一下索引的字段的长度就可以。下面说下遇到的具体情况。
创建一个数据表
create table if not exists `options`( `option_id` bigint(20) unsigned not null auto_increment, `option_name` varchar(251) not null default '', `option_value` longtext not null, `autoload` varchar(20) not null default 'no', primary key (`option_id`), unique key (`option_name`) ) engine=myisam default charset=utf8mb4;
如果直接执行出现的错误是 (Specified key was too long; max key length is 1000 bytes)
出现的原因
- 索引过长超过的 1000
- 数据表引擎myisam的限制
修改的方式有两种,任何一种都可以修改
-
删除索引
unique key (
option_name
) - 修改索引的长度
说明1
索引的长度限制是1000, 因为 utf8mb4
一个字符是占用4个字节,所以修改的数要小 (1000/4 =250)
说明2
Specified key was too long; max key length is 767 bytes
如果遇到了可能用的是 innodb 的引擎
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Rust编程之道
张汉东 / 电子工业出版社 / 2019-1 / 128
Rust 是一门利用现代化的类型系统,有机地融合了内存管理、所有权语义和混合编程范式的编程语言。它不仅能科学地保证程序的正确性,还能保证内存安全和线程安全。同时,还有能与C/C++语言媲美的性能,以及能和动态语言媲美的开发效率。 《Rust编程之道》并非对语法内容进行简单罗列讲解,而是从四个维度深入全面且通透地介绍了Rust 语言。从设计哲学出发,探索Rust 语言的内在一致性;从源码分析入......一起来看看 《Rust编程之道》 这本书的介绍吧!