我想编写一个SQL查询,该查询在文本字段中搜索关键字,但是仅当它是“全字匹配”时(例如,当我搜索“ rid”时,它不应该与“ arid”匹配,但是应该匹配“摆脱”。
我正在使用MySQL。
幸运的是,在该应用程序中性能并不是至关重要的,并且数据库大小和字符串大小都非常小,但是我更喜欢在SQL中而不是在PHP中驱动它。
您可以使用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
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。