|
3#
楼主 |
发表于 2013-8-15 13:02:37
|
只看该作者
这个erp系统是一个外销机械加工企业使用的。在编写过程中有很多是技术问题,至于和企业使用人员以及老板的沟通也是很重要的。
就说今天这个问题吧。这个问题是技术问题,我自己发现的。
就是在家使用vpn连接企业的的sql数据库的时候第一次连接老是连接不上。其实这个企业的使用者是不知道的,但是我却知道这个问题。做程序的,就是要完美的。
我通过网络查询,有几篇文章涉及到这个问题,但是我看到其中一篇文章最有价值。
这个文章是这样的:
SQL Server Full text第一次使用会timeout的问题
2012-04-20 13:05:56 我来说两句 收藏 我要投稿
SQLServer Full text第一次使用会timeout的问题
最近遇到一个比较奇怪的问题,为了提升一个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;
我在企业的sql2005中运行查询 sp_fulltext_service 'verify_signature',0 这个是全文索引
解决了问题。心情很舒畅的。学无止境。我相信一句话:只有想不到,没有做不到。 |
|