AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 778747
Accepted
Matt James
Matt James
Asked: 2016-05-25 07:57:09 +0800 CST2016-05-25 07:57:09 +0800 CST 2016-05-25 07:57:09 +0800 CST

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

  • 772

我正在迁移到 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 索引

innodb amazon-web-services amazon-rds full-text-search
  • 1 1 个回答
  • 959 Views

1 个回答

  • Voted
  1. Best Answer
    Matt James
    2016-05-28T04:12:36+08:002016-05-28T04:12:36+08:00

    好的,我想通了。看起来好像在 MyISAM 表中,即使没有单独的 FULLTEXT 键作为名称或描述,我对名称和描述字段的查询也有效。即,在我上面的定义中,您可以看到我已经为 的组合添加了一个 FULLTEXT INDEX name_description,但是在我的查询中,我也分别针对这些列。在 MyISAM 中,这是可行的。在 InnoDb 中,它没有。

    解决方案是在组合索引旁边为名称和描述创建单独的 FULLTEXT INDEX。现在我的查询效果很好!

    • 0

相关问题

  • drupal 的 MySQL 配置

  • 奇怪的mysql表问题

  • 以最少的停机时间更改大型 Innodb 表上的列长度

  • 在使用 InnoDB 数据库之前我应该​​知道什么?

  • 如何选择 MySQL 数据库引擎

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve