原系统为SQLServer 2008 R2,全文索引搜索正常(不能跟Like比,少几条也还算正常,影响不大);升级为SQL Server 2012后,用CONTAINS谓词进行搜索,发现有的关键词搜索结果为0,有的搜索结果只有以前的一半不到,而用Like搜索则全部正常。

查阅微软资料,http://msdn.microsoft.com/zh-cn/library/ms142490.aspx

如果在将 SQL Server 2005 数据库升级到 SQL Server 2012 时导入了全文目录,则由于旧断字符和新断字符的行为略有差异,可能会出现查询和全文索引内容不匹配。 在这种情况下,若要保证查询和全文索引内容之间的完全匹配,请选择以下选项之一:

 

有此想到,可能就是因为断字符导致有的关键词搜索不到结果,果断重新生成全文目录,在查询分析器中执行如下命令:

ALTER FULLTEXT CATALOG xxxx_Catalog REBUILD

CPU狂飙一会儿后,再用CONTAINS进行测试,终于正常了。由此可见,SQL Server 2005/2008 和 2012还是很大不同的,至少在断字符上,变化很大。

posted on 2013-04-26 17:23  Wesley.GONG  阅读(516)  评论(0编辑  收藏  举报