我昨天在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))。
接下来我应该尝试什么?