收藏本站 
广告服务 
网站地图 
>> 我们从网络和杂志上收集了近100000余篇各类电脑技术、网络技术、软件技术等方面的文章教程,我们的收录原则:不是精华拒不收录!
先飞电脑技术网技术文章
网络编程 | 网站建设 | 网络技术 | 设计教程 | 软件教学 | 程序开发 | 数据库开发 | 教育认证 | 硬件维护 | 媒体动画 | 机械电子 |
不可小视视图对效率的影响力
[ 作者:佚名    转贴自:网络转载    阅读次数:79    更新时间:2007-8-12 10:10:00   录入:刘光勇 ]         
    近日为一家企业开发数据库方面的应用。

有两张数据表:A和B,其中A的记录为2万条左右,而B中的数据为200万条以上,现在要求以a.id=b.id为关联进行数据筛选。

为此要求,我做了个视图View1,将a.id与b.id关联起来,运行该视图的查询,使用了2秒中就得到结果了。

这时又有一特殊需求:编写存储过程,该存储过程中有一个游标的循环,该循环重复1万次,在每次循环中都使用了对View1的查询。

举例如下:

循环游标体(重复1万次)

{ select @text=text from view1 whereid=@id 
--其中@text,@id均为变量

update form1 set text=@text where id=@id}

执行以上的存储过程,发现竟然要花费>7分钟的运算时间,进行分析后得知效率全损耗在对view1视图的扫描上,尽管单独对该视图进行查询只需2秒,但在这种情况下即需要太多的时间。

因此改进该存储过程如下:

create table #tempTab( id nvarchar(20), text nvarchar(20))

查询View1视图,将记录插入到#tempTab临时表中... 循环游标体(重复1万次)

{ select @text=text from #tempTab whereid=@id 
--其中@text,@id均为变量

update form1 set text=@text where id=@id}

别小瞧以上的改动,此时该存储过程只花费50秒的时间。 对于上述现象,分析如下:在多次循环对某个视图进行查询时,将会耗费大量的时间,因此将该视图的数据放在内存中进行计算会在很大程度上提高速度。

【加入到收藏夹】告诉好友】【打印此文】【关闭窗口
  版权声明:本站提供的“不可小视视图对效率的影响力”版权归文章所有者,转载请注明出处!
 ·上一篇文章:使用SQL 2000将现有代码作为Web服务提供      ·下一篇文章:SQL Server数据库被置疑的解决方法
相关文章
·清除不可杀病毒的技巧[22]
·家称不可能从技术上根除钓鱼网站欺诈[10]
·如何让网络坚不可摧 交换机安全六则[24]
·利用多层次安全机制让VoIP网络坚不可摧[78]
·注重交换机安全 让网络坚不可摧[100]
网站主页 | 收藏本页 | 联系我们 | 广告服务 | 站点地图 | 会员注册 | 招聘信息 | 内容指正

联系QQ:先飞电脑技术网站事务联系QQ,点击可以直接留言. 32933427 电话:13710542091 [世界排名] 鄂ICP备05005890号