最近遇到一个比较奇怪的 问题 ,为了提升一个Search Function的性能,为此建立了全文索引,然后用Contains语句来降低查询时间。 SELECT * FROMTABLE_AWHERE CONTAINS(Field1,'ABC|DFD|FD') 使用 Contains查询确实比较很快。不过 问题 是每过约20分钟左右的时
最近遇到一个比较奇怪的 问题 ,为了提升一个Search Function的性能,为此建立了全文索引,然后用Contains语句来降低查询时间。
SELECT * FROM TABLE_A WHERE CONTAINS(Field1,'ABC|DFD|FD')
使用 Contains查询确实比较很快。不过 问题 是每过约20分钟左右的时间;再次 使用 contains查询会很慢,甚至会超时,第2次,第3次..则又非常快。如此的重复着。 开始的时候我怀疑是因为SQLServer的 Data Cache 问题 ,所以用WITH Recomplie Option等方式去解决不 使用 Cache的,但仍然没有任何效果, 问题 还是继续出现。且这个 问题 只是出现在某一个环境下。
最后证实 问题 的罪魁祸首是一个SQLServer的一个配置( VerifySignature ). 唯独在这个环境中 VerifySignature 属性被设为了1,其他的环境都是0.
查询配置的语句:
SELECT fulltextserviceproperty ( 'VerifySignature' )
当 VerifySignature 被设置成1时。
当 第一 次query的时候,SQLServer 会尝试连到Internet 上 验证word breaker证书. 接下来的第二次则不会再去验证。
验证需要花一些时间,尤其当SQLServer没有网络连接的时候。
如果在5分钟里并没有其他的Full text search被行的话, the word breaker会被Unload掉,然后再次执行证书验证。这就是为什么我会遇到这样奇怪的 问题 .
解决办法:
sp_fulltext_service 'verify_signature' , 0 ;
查看更多关于SQLServerFulltext第一次使用会timeout的问题的详细内容...