逗号分隔关键字

时间:2016-01-21 15:57:45

标签: sql sql-server

搜索字符串被传递给我们拥有的存储过程,例如

"this is a search string".

现在,搜索查询是这样的:

Select * From Table Where Keywords Like '%this is a search string%'

"关键字"数据库中的列存储以逗号分隔的值,因此在这种情况下:

"this, is, a, search, string"

显然上面的查询不会返回任何结果,我今天下午已经花了很多时间来弄清楚如何做到这一点。

2 个答案:

答案 0 :(得分:1)

正如评论中所提到的,这是存储关键字的错误方法。您应该有一个表,每个实体一行,每个关键字一行。

有时,我们会遇到其他人糟糕的设计决策。如果是这样,您可以使用Google进行拆分功能并执行以下操作:

and

这会给你比赛。如果您想ortable(您的问题没有指定),那么您将在having的主键上使用聚合并包含相应的{{1 }。clause。

答案 1 :(得分:1)

使用此处的功能:http://sqlperformance.com/2012/07/t-sql-queries/split-strings

CREATE FUNCTION dbo.SplitStrings_Moden
(
   @List NVARCHAR(MAX),
   @Delimiter NVARCHAR(255)
)
RETURNS TABLE
WITH SCHEMABINDING AS
RETURN
  WITH E1(N)        AS ( SELECT 1 UNION ALL SELECT 1 UNION ALL SELECT 1 UNION ALL SELECT 1 
                         UNION ALL SELECT 1 UNION ALL SELECT 1 UNION ALL SELECT 1 
                         UNION ALL SELECT 1 UNION ALL SELECT 1 UNION ALL SELECT 1),
       E2(N)        AS (SELECT 1 FROM E1 a, E1 b),
       E4(N)        AS (SELECT 1 FROM E2 a, E2 b),
       E42(N)       AS (SELECT 1 FROM E4 a, E2 b),
       cteTally(N)  AS (SELECT 0 UNION ALL SELECT TOP (DATALENGTH(ISNULL(@List,1))) 
                         ROW_NUMBER() OVER (ORDER BY (SELECT NULL)) FROM E42),
       cteStart(N1) AS (SELECT t.N+1 FROM cteTally t
                         WHERE (SUBSTRING(@List,t.N,1) = @Delimiter OR t.N = 0))
  SELECT Item = SUBSTRING(@List, s.N1, ISNULL(NULLIF(CHARINDEX(@Delimiter,@List,s.N1),0)-s.N1,8000))
    FROM cteStart s;

你可以做这样的事情

SELECT a.pk, COUNT(*) AS hits
FROM Table AS a
CROSS APPLY dbo.SplitStrings_Moden(a.Keywords, ',') b
WHERE 
    CHARINDEX(b.Item, 'this is a search string') > 0
GROUP BY a.pk
ORDER BY COUNT(*) DESC

基本上,您正在创建一个Keyword值的分析表。然后,您搜索以查看哪些包含搜索字符串中的Keyword,按主键分组和按命中排序。