我们有几个全文索引字段的表。比如,它是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。
答案 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