我正在迁移到 RDS 上的 MariaDB。我的表已启动并运行,一切看起来都很好,但考虑到我使用的是 MariaDB 10.0.24,我正在考虑将我的几个 MyISAM 表切换到 Innodb。在此之前,我需要使用 MyISAM,因为 InnoDb 不支持全文。但据我了解,MariaDB > 10.0.5 支持在 InnoDB 上进行全文搜索。
在我的第一次尝试中,我使用以下方法将表从 MyISAM 转换为 InnoDB:
ALTER TABLE `courses` ENGINE=INNODB
但之后,我的 FULLTEXT 索引似乎被重置了。它们仍然列在那里,但不响应 FULLTEXT 搜索。
Can't find FULLTEXT index matching the column list
另外,当我尝试在表上创建新的 FULLTEXT INDEXES 时,我无法再创建它们 - 只有 INDEX 和 UNIQUE 可用。
最后,虽然我在 RDS 参数组中看到了允许我配置 INNODB FULLTEXT 设置的设置,但我没有看到任何允许我“打开它”的设置,所以我假设它默认是开启的。
我是否只能使用 MyISAM,或者是否可以将这些表更改为 InnoDB,而我只是还没弄清楚如何做到这一点?
感谢您的帮助!
更新:
显示创建表:
CREATE TABLE `courses` (
`id` varchar(32) NOT NULL,
`name` varchar(255) DEFAULT NULL,
`description` text,
`instructor_id` varchar(32) DEFAULT NULL,
`catalog_id` varchar(32) NOT NULL,
`site_id` varchar(32) NOT NULL,
`created_on` datetime NOT NULL,
`modified_on` datetime NOT NULL,
PRIMARY KEY (`id`),
KEY `site_id` (`site_id`),
KEY `instructor_id` (`instructor_id`),
KEY `catalog_id` (`catalog_id`),
FULLTEXT KEY `name_description` (`name`,`description`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
询问:
SELECT `c`.*, (MATCH (c.name) AGAINST ('+yoga*' IN BOOLEAN MODE)) AS `nameRelevance`, (MATCH (c.description) AGAINST ('+yoga*' IN BOOLEAN MODE)) AS `descriptionRelevance` FROM `courses` AS `c` WHERE (c.catalog_id IN ('xxxxx')) AND (c.site_id = 'yyyyy') AND (MATCH (c.name, c.description) AGAINST ('+yoga*' IN BOOLEAN MODE) OR MATCH (c.name, c.description) AGAINST ('+yoga*' IN BOOLEAN MODE))
错误:找不到与列表匹配的全文索引
答案1
好的,我明白了。看起来好像在 MyISAM 表中,即使没有单独的名称或说明的 FULLTEXT 键,我对名称和说明字段的查询也可以工作。即,在上面的定义中,您可以看到我为组合添加了一个 FULLTEXT INDEX name_description
,但在我的查询中,我也分别针对这些列。在 MyISAM 中,这有效。在 InnoDb 中,它不起作用。
解决方案是除了组合索引之外,还为名称和描述创建单独的全文索引。现在我的查询运行良好!