我正在迁移到 RDS 上的 MariaDB。我的表已启动并正在运行,一切看起来都不错,但鉴于我使用的是 MariaDB 10.0.24,我正在考虑将我的几个 MyISAM 表切换到 Innodb。在此之前,我需要使用 MyISAM,因为 InnoDb 不支持全文。但是,据我了解,MariaDB > 10.0.5 支持在 InnoDB 上进行全文搜索。
在我的第一次尝试中,我使用以下方法将表从 MyISAM 转换为 InnoDB:
ALTER TABLE `courses` ENGINE=INNODB
但在那之后,我的 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))
错误:找不到与列列表匹配的 FULLTEXT 索引
好的,我想通了。看起来好像在 MyISAM 表中,即使没有单独的 FULLTEXT 键作为名称或描述,我对名称和描述字段的查询也有效。即,在我上面的定义中,您可以看到我已经为 的组合添加了一个 FULLTEXT INDEX
name_description
,但是在我的查询中,我也分别针对这些列。在 MyISAM 中,这是可行的。在 InnoDb 中,它没有。解决方案是在组合索引旁边为名称和描述创建单独的 FULLTEXT INDEX。现在我的查询效果很好!