4

我们有一个位置搜索页面,这给我们带来了我以前从未遇到过的挑战。

在我们的数据库中,我们有一个带有相应地理编码的城市、州等列表。直到现在一切都很有趣......

我们在一个名为“威斯康星州黑河瀑布”的城市有两个地点,我们最近在“威斯康星州河瀑布”开设了一个。

所以我们的表有如下记录:

Location    City                State
-------------------------------------
1           Black River Falls   WI
2           Black River Falls   WI
3           River Falls         WI

显然我们的查询使用“LIKE”子句来匹配城市,但是当客户搜索文本“River Falls”时,在搜索结果中,显示的第一个结果始终是“Black River Falls”。

在我们的应用程序中,我们总是使用第一个匹配项,并将其用作默认值。(我们可以改变它,但这将是很多未列入预算的工作)

我知道我可以简单地更改排序顺序以首先出现“River Falls”,但这是一个草率的解决方案,仅适用于这种情况。

我想知道是否有一种方法,通过 T-SQL (SQL Server 2008r2) 按“最佳匹配”排序,如果我们搜索“River Falls, WI”和“Black”,“River Falls”将“获胜”如果我们搜索“Black River Falls”WI,River Falls”会起作用。

4

2 回答 2

12

您可以使用“ DIFFERENCE ”功能使用最接近的SOUNDEX匹配进行搜索。

Select * From Locations WHERE City=@City ORDER BY Difference(City, @City) DESC

从 MSDN 文档:

返回的整数是 SOUNDEX 值中相同的字符数。返回值的范围是 0 到 4:0 表示弱相似或没有相似性,4 表示强相似或相同的值。

DIFFERENCE 和 SOUNDEX 是校对敏感的。

于 2013-08-26T21:52:54.327 回答
5

像这样:

;WITH cte As
(
    SELECT  *
        ,   ROW_NUMBER() OVER(ORDER BY LEN(City)-LEN(@UserText)) As MatchPrio
    FROM    Cities
    WHERE   City LIKE '%'+@UserText+'%'
)
SELECT *
FROM    cte
WHERE   MatchPrio = 1

更新:

您可以将上面的 ORDER BY 表达式更改为也使用DIFFERENCE(..)或任何其他条件组合。

于 2013-08-26T21:53:38.623 回答