6

我昨天在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 子句中都可以正常运行。桌子上有一些Annes,大约和Annas一样多。

每次查询失败时,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))。

接下来我应该尝试什么?

4

1 回答 1

3

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

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

如果您运行与大量行匹配的查询,该错误可能会再次发生,对于您增加的sort_buffer_size.

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

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

于 2019-03-28T18:39:17.693 回答