开发者社区> 问答> 正文

在MySQL中搜索“全字匹配”

我想编写一个SQL查询,该查询在文本字段中搜索关键字,但是仅当它是“全字匹配”时(例如,当我搜索“ rid”时,它不应该与“ arid”匹配,但是应该匹配“摆脱”。

我正在使用MySQL。

幸运的是,在该应用程序中性能并不是至关重要的,并且数据库大小和字符串大小都非常小,但是我更喜欢在SQL中而不是在PHP中驱动它。

展开
收起
保持可爱mmm 2020-05-11 15:52:20 411 0
1 条回答
写回答
取消 提交回答
  • 您可以使用REGEXP和[[:<:]]和[[:>:]]字边界标记:

    SELECT * FROM table WHERE keywords REGEXP '[[:<:]]rid[[:>:]]' 2020年更新:(实际上是2018年以上)

    MySQL在8.0.4版中更新了RegExp-Engine,因此您现在需要使用 “ 标准 ”字边界标记\ b:

    SELECT * FROM table WHERE keywords REGEXP '\brid\b' 另请注意,您需要通过放置第二个反斜杠来逃避反斜杠。来源:stack overflow

    2020-05-11 15:52:31
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
One Box: 解读事务与分析一体化数据库 HybridDB for MySQL 立即下载
One Box:解读事务与分析一体化数据库HybridDB for MySQL 立即下载
如何支撑HTAP场景-HybridDB for MySQL系统架构和技术演进 立即下载

相关镜像