打开procedure一段一段执行却没问题,执行整个procedure的内容也没问题,但是execprocedure_nm却始终有问题,下面有个不错的解决方法,大家可以参考下
问题描述:

有一次在发布系统到production环境之后,突然发现报表过了好几分钟也刷新不出来,小哥我直接就慌神了。迅速进行各种测试,首先右键报表属性找出报表地址,看看参数是否传对了。找出报表参数之后直接运行procedure,也跑不出来。打开procedure一段一段执行却没问题,执行整个procedure的内容也没问题,但是exec procedure_nm却始终有问题。在开发环境execute procedure,也没问题。于是,开始纠结了。

环境:SQL SERVER 2008, SSRS 2008

解决过程:

仔细思考production环境和开发环境的不同,无非就是开发环境是新搭建的环境,production是已经存在好几年的环境,这次只是对其报表producdure进行了改变,并打了一个补丁修改之前半年的历史数据。后来发现这里就是引起这次事情的主要原因。通过不断的查找问题,发现了开发环境和production里面的表统计信息(在SQL SERVER里面左侧目标浏览器中展开表之后的最下面一个项目:Statistics)不一样。当时只是一个猜测,大量跟新数据会引起production的统计信息过时,而SQL SERVER引擎在解析procedure的时候会根据统计信息制定一系列数据检索计划,就像以前从A市到B市有一条高速公路,现在这条高速公路没用了,SQL SERVER引擎就去寻找其他笨的方法,而统计信息的自动更新只会发生在夜深人静之时。所以便尝试着去申请手动更新production的统计信息。统计信息更新之后,报表能够正常打开了。

解决方法:

USE Database_nm

EXEC sp_UpdateStats

结论:

在大量更新数据之后,会使数据库的统计信息发生变化,继而影响SQL SERVER对SQL的解析。需要重新更新数据库的统计信息,让SQL SERVER参考最新的正确的信息去制定执行计划。
最新资讯
太空中的太阳能或许可以满足地球的能源需求

太空中的太阳能或许可

欧洲航天局已经意识到这些工作的潜力,同时也在为这些项
别骗自己,用上高通基带iPhone 12仍然信号差

别骗自己,用上高通基带

iPhone的信号,薛定谔的信号,游走于刚好能用的标准线上下
上破19000大关后一度重挫3000美元,比特币怎么了?

上破19000大关后一度

在周三触及19490美元高点后,比特币近两日出现重挫,其他
视频号:成也微信,败也微信

视频号:成也微信,败也微

短短半年多,微信视频号就“十八般武器”整齐活了,这在整
京东优选即将上线,整合内部四个社区团购业务

京东优选即将上线,整合

据悉,京东内部正筹划名为“京东优选”的社区团购项目。
央行:三季度移动支付业务量保持增长态势

央行:三季度移动支付业

央行披露2020年第三季度支付体系运行总体情况:移动支付
最新文章
电脑ping命令的结果怎么输出到txt文本?

电脑ping命令的结果怎

电脑ping命令的结果怎么输出到txt文本?电脑在使用ping
使用SSD硬盘空间清理 C盘爆满怎么办

使用SSD硬盘空间清理

这篇文章主要为大家介绍了使用ssd的朋友,对于c盘空间比
如何给图片添加标记? 电脑给图片添加标记的教程

如何给图片添加标记?

如何给图片添加标记?想要给图片添加标记,电脑怎么给图片
电脑win键失效怎么办? 键盘win键无效的解决办法

电脑win键失效怎么办?

电脑win键失效怎么办?在使用windows系统的时候,发现一个
电脑怎么查看ip地址和路由器网关? 查看网关ip地址的技巧

电脑怎么查看ip地址和

电脑怎么查看ip地址和路由器网关?电脑想要查看ip地址和
电脑怎么实现批处理ping多个ip? 批处理扫描网段技巧

电脑怎么实现批处理pi

电脑怎么实现批处理ping多个ip?我们需要凭一个网段,看看