当文本跨越多列时,如何使用AND进行全文查询

时间:2010-01-15 15:24:34

标签: sql sql-server-2005 full-text-search

我们有几个全文索引字段的表。比如,它是firstName,surName和lastName。我正在寻找“John AND Smith”,显然这两个词最有可能写在不同的领域。查询什么都不返回如果我搜索“John OR Smith”,它就可以了。

问题是:我能以某种方式告诉SQL Server属于特定表的一行的所有字段应该被视为一个连续的文本片段吗?

当然,我可以手动将字段连接到特殊字段并对其进行索引,但它看起来很傻。

以防万一,查询。这不是关于人的名字,但想法是一样的:

SELECT [id], [type], [accessClass], [rank] 
FROM ( 
SELECT DISTINCT temp_result.* 
FROM ( 
    select SDF_Article.article_id [id], 
    6 [type], SDF_Object.accessClass [accessClass], RelevanceTable.[rank] [rank] 
    from SDF_Article inner join SDF_Object SDF_Object 
    on SDF_Article.article_id=SDF_Object.object_id 
    inner join SDF_Article_Locale SDF_Article_Locale 
    on SDF_Article.article_id=SDF_Article_Locale.article 
    inner join ContainsTable(SDF_Article_Locale, (title, body, brief),
    'FORMSOF (INFLECTIONAL, hello) AND FORMSOF (INFLECTIONAL, world)', Language 'Russian') RelevanceTable 
    on SDF_Article_Locale.entry_id=RelevanceTable.[KEY] 
    ) AS temp_result 
INNER JOIN SDF_RelationMap SDF_Map 
ON temp_result.[id] = SDF_Map.object AND SDF_Map.ancestor = 5 ) 
AS result ORDER BY [rank] desc

我们正在使用SQL Server 2005。

2 个答案:

答案 0 :(得分:2)

一种解决方案是创建一个自动填充的列,该列可以对要编制索引和搜索的列进行连接。然后将全文索引器指向此列。然后,您只需围绕新列形成查询。

答案 1 :(得分:0)

事实证明在SQL Server中没有对此的支持。更重要的是,这种行为在2004年被“修复”: http://support.microsoft.com/default.aspx?scid=kb;en-us;294809

我在MS Connect中添加了建议。请支持: https://connect.microsoft.com/SQLServer/feedback/ViewFeedback.aspx?FeedbackID=526862