动网论坛,站长建站首选,国内使用量最多的论坛软件 动网论坛官方技术讨论区 站长工具 申请属于您自己的免费论坛
首页 | 新闻资讯 | 网站运营 | 网络编程 | 数据库 | 服务器 | 网页设计 | 图像媒体 | 网络应用 | 搜索优化 | 资源下载 | 动网主机 | DVBOX
    本站内  互联网 ASP论坛  ASP.Net论坛  PHP论坛
   数据库 → 阅读文章

 不可小视视图对效率的影响力

作者:无从考证 来源:转载 
阅读 数 483 人次 , 2006-2-15 17:52: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 where id=@ 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 where id=@ id    --其中@text,@id均为变量
   update form1 set text=@text where id=@id
}
别小瞧以上的改动,此时该存储过程只花费50秒的时间。
对于上述现象,分析如下:在多次循环对某个视图进行查询时,将会耗费大量的时间,因此将该视图的数据放在内存中进行计算会大提高速度。

  
 本文Tags视图  优化  
 收藏本文  打印本文  论坛讨论  关闭窗口
· 上一篇:关于日期天数计算的函数
· 下一篇:数据库设计中的反规范技术探讨
· 循序渐进学习Power Builder 6.0(5-0)
· MySQL Join详解
· SQL查询语句精华使用简要
· SQL Server数据库技术(01)
· 使用db2look 重新创建优化器访问计划


关于本站 | 联系我们 | 业务合作 | 客户案例 | 诚聘英才 | 广告合作 | 收藏本站
海口动网先锋网络科技有限公司版权所有
Copyright © 2000 - 2006 Cndw.Com
中华人民共和国电信与信息服务业务经营许可证编号 琼 ICP 020077