gpt4 book ai didi

MySQL 错误 1032 "Can' t 在表中找不到记录”

转载 作者:行者123 更新时间:2023-12-02 03:46:47 25 4
gpt4 key购买 nike

我昨天在 dba.stackexchange.com 上问了这个问题没有得到任何回复,所以我在这里尝试。

我的数据库中的某些查询出现 MySQL 1032“无法在‘person’中找到记录”错误,并且无法解决这些错误。

这是表格:

CREATE TABLE `person` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`last_name` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci DEFAULT NULL,
`first_name` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci DEFAULT NULL,
`title` varchar(200) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci DEFAULT NULL,
`dob` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci DEFAULT NULL,
PRIMARY KEY (`id`),
FULLTEXT KEY `person_full_idx` (`last_name`,`first_name`,`title`)
) ENGINE=InnoDB AUTO_INCREMENT=4448 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;

失败的查询是

SELECT * FROM person p0_
WHERE MATCH (p0_.last_name , p0_.first_name , p0_.title) AGAINST ('anne' IN BOOLEAN MODE) > 0.5
ORDER BY p0_.last_name ASC, p0_.first_name ASC, p0_.dob ASC;

如果我取出任何一个 order by 子句,查询就会正常运行。如果我将 anne 更改为 anna,则查询对于所有三个 order by 子句都运行得很好。表中有一些安妮,大约与安娜的数量一样多。

每次查询失败时,MySQL 错误日志都会有一堆这样的错误消息:

2019-03-27T17:31:27.891405Z 9 [Warning] [MY-012853] [InnoDB] Using a
partial-field key prefix in search, index `FTS_DOC_ID_INDEX` of table
`database`.`person`. Last data field length 8 bytes, key ptr now
exceeds key end by 4 bytes. Key value in the MySQL format:
len 4; hex 05110000; asc ;

我没有使用复制,并且对 anne 记录的插入、更新和删除均成功。我删除并重新创建了全文索引,但没有任何改进。我删除并重新加载数据库并得到相同的错误。

使用相同的数据,查询在生产环境(mysql Ver 15.1 Distrib 10.1.37-MariaDB)中不会失败。据我所知,它只在我的开发机器上失败(mysql Ver 8.0.15 for osx10.14 on x86_64 (Homebrew))。

接下来我应该尝试什么?

最佳答案

正如上面评论中所指出的,这是 MySQL 8.0 中的一个已知错误:https://bugs.mysql.com/bug.php?id=93241

临时解决方法是增加 sort_buffer_size 的大小。默认sort_buffer size in MySQL 8.0为 256KB,您可以配置的最大值为 2^32-1 或 2^64-1。

如果您运行的查询匹配的行数较多,以至于对于增加的 sort_buffer_size 来说太大,则可能会再次出现该错误。

我警告不要将 sort_buffer_size 增加得非常大,因为运行此查询的每个线程都会分配自己的排序缓冲区。

假设您将 sort_buffer_size 增加到 1GB,然后 100 个并发客户端同时运行全文搜索!您可能会意外地使 MySQL 超出您的系统总内存,并且当发生这种情况时您不会收到任何警告。

关于MySQL 错误 1032 "Can' t 在表中找不到记录”,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55403537/

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