微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

SQLSERVER全文索引的一个BUG

在产品开发中,需要用到数据库全文索引特性,于是对sqlServer数据库的表建立了全文索引,如对资源收集来源表进行全文索引,表结构如下:

create table res_original
(
 res_id bigint,
 res_title varchar(100),
 res_content varchar(8000)
)

至于如何建立全文索引,请看上一篇BLOG. 现在要对 res_title 和 res_content 二个字段都开启全文索引,在查询时用如下语句查:

select * from res_original a
where CONTAINS(a.*,@keyword)

我希望在开启全文索引的二个字段中都查找,其中,@keyword 为外部传入的查询内容. 一切工作正常,但是,如果 @keyword 的内容为列 res_title 的某一行的全部内容时,则查询

不到此行数据,如:假设在 res_title 列中有一行内容为 "sqlSERVER数据库全文索引示例",而 @keyword 的内容正好也为 "sqlSERVER数据库全文索引示例" 时,则查询结果中是

没有此行数据的,但用如下语句能查到:

select * from res_original a
where res_title = @keyword

这就说明表中是实实在在存在要查的数据,当然,全文索引相关的一切工作配置都没问题. 在上面查询示例中,如果去掉 "sqlSERVER数据库全文索引示例" 中的 最后一个字,变为

"sqlSERVER数据库全文索引示",传给 @keyword 来查询,是能查询此行数据的. 经过多次测试,感觉这是 sqlServer(2000以上)的一个BUG,或者是另有说法,但本人不得而知. 

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐