gpt4 book ai didi

mysql - SQL 键长度错误没有意义

转载 作者:行者123 更新时间:2023-11-29 01:14:23 25 4
gpt4 key购买 nike

以下在我看来完全合理:

CREATE TABLE `mydb`.`Temp` (
`id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
`x` VARCHAR ( 300 ) NOT NULL ,
`id_foo` INT NULL DEFAULT NULL,
FOREIGN KEY ( `id_foo`) REFERENCES `Foo` (`id`) ON DELETE CASCADE ,
INDEX (`id_foo`),
INDEX (`x`),
UNIQUE (`id_foo`, `x`)
) ENGINE = INNODB;

对于 MySQL,这会产生错误

#1071 - Specified key was too long; max key length is 767 bytes

这似乎是错误的,因为整行是 309 字节:不到 767,甚至不到一半。怎么回事?

最佳答案

根据 MYSQL 文档:http://dev.mysql.com/doc/refman/5.0/en/create-index.html

MySQL 对可用于定义列索引的空间量有不同的限制

  • 对于 MyISAM,它是 1,000 字节;
  • 对于 InnoDB,它是 767。

此外,这些列的数据类型很重要 - 对于 VARCHAR,是 3x

因此,VARCHAR(300) 上的索引就像在您的表中一样,将占用其中的 900 个字节,即大于 767 字节的最大键长度。

编辑: 显然这不是 MySQL 的错误,而是 MySQL 中的 UTF8 最多支持 3 个字节。此外,引入 4 字节 utf8 字符集 (WL#1213)最大可能的 key 长度从 255 变为 191 个字符(191 * 4 + 2 = 766,其中 2 个字节用于长度)。从 MySQL 5.5 或更高版本开始,所有 -utf、-utf8mb4、-utf16、-utf32 都受到此更改的影响。

关于mysql - SQL 键长度错误没有意义,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9604255/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com