- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
以下在我看来完全合理:
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 对可用于定义列索引的空间量有不同的限制
此外,这些列的数据类型很重要 - 对于 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/
我正在使用 Gunicorn 为 Django 应用程序提供服务,它工作正常,直到我将其超时时间从 30 秒更改为 900000 秒,我不得不这样做,因为我有一个用例需要上传和处理一个巨大的文件(过程
我有一个带有非常基本的管道的Jenkinsfile,它可以旋转docker容器: pipeline { agent { dockerfile { args '-u root' } } stag
在学习 MEAN 堆栈的过程中,我遇到了一个问题。每当我尝试使用 Passport 验证方法时,它都不会返回任何响应。我总是收到“localhost没有发送任何数据。ERR_EMPTY_RESPONS
在当今的大多数企业堆栈中,数据库是我们存储所有秘密的地方。它是安全屋,是待命室,也是用于存储可能非常私密或极具价值的物品的集散地。对于依赖它的数据库管理员、程序员和DevOps团队来说,保护它免受所
是否可以创建像图片上那样的边框?只需使用 css 边框属性。最终结果将是没 Angular 盒子。我不想添加额外的 html 元素。我只想为每个 li 元素添加 css 边框信息。 假设这是一个 ul
我是一名优秀的程序员,十分优秀!