您的位置:首页 > 数据库

SQL Server 2008升级到2012后全文索引搜索不到结果的解决方法

2013-04-26 17:23 447 查看
原系统为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 catalog_name REBUILD)

对全文索引执行 FULL POPULATION (ALTER FULLTEXT INDEX ON table_name START FULL POPULATION)。

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

ALTER FULLTEXT CATALOG xxxx_Catalog REBUILD

CPU狂飙一会儿后,再用CONTAINS进行测试,终于正常了。由此可见,SQL Server 2005/2008 和 2012还是很大不同的,至少在断字符上,变化很大。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: