如何在 AWS RDS 上的 MariaDB 中配置全文 InnoDb 功能?

如何在 AWS RDS 上的 MariaDB 中配置全文 InnoDb 功能?

我正在迁移到 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 中,它不起作用。

解决方案是除了组合索引之外,还为名称和描述创建单独的全文索引。现在我的查询运行良好!

相关内容