如何使用 SQL 在查询语句中查找最长匹配?

Posted

技术标签:

【中文标题】如何使用 SQL 在查询语句中查找最长匹配?【英文标题】:How to find longest match in a query sentence using SQL? 【发布时间】:2017-09-29 20:51:08 【问题描述】:

假设我有一张这样的桌子:

----------------------------------
|id |phrase
----------------------------------
|1  |real
|2  |testing
|3  |real message
|4  |testing message
|5  |special testing message

目标是找到查询语句中最长匹配的id。例如,查询语句This is a testing message 应该返回4

我用的是phpmysql,所以如果单独用SQL做太复杂,部分操作可以切换到PHP。目前我正在把整个表格拿出来并在 PHP 上一一做正则表达式,但如果表格变大,效率会很低。有没有办法将一些工作负载切换到 SQL,这样我就不需要将整个表存储到内存中?

【问题讨论】:

试试 LEN() 函数。 link @JoãoPaulodeLima LEN() 如何解决这个问题? 对不起,cytsunny。其实我以为你想得到最长的短语。但现在我看到它需要匹配你的句子 【参考方案1】:

使用CONCATLENGTHLIMIT

SELECT id FROM table
WHERE ('.$search_term.' LIKE CONCAT("%",phrase,"%"))
ORDER BY LENGTH(phrase) DESC LIMIT 1

【讨论】:

以上是关于如何使用 SQL 在查询语句中查找最长匹配?的主要内容,如果未能解决你的问题,请参考以下文章

如何在 Oracle SQL 中查找最具体的匹配行

如何查找MySQL中查询慢的SQL语句

如何查找MySQL中查询慢的SQL语句

数据库笔记-SQL过滤(LIKE&正则表达式)

如何查找MySQL中查询慢的SQL语句

如何查找MySQL中查询慢的SQL语句