设为首页 加入收藏

TOP

如何解决存储过程中关联临时表时快时慢的情况
2015-07-24 12:13:43 来源: 作者: 【 】 浏览:75
Tags:如何 解决 存储 过程 关联 临时 时快时 情况

调用一个存储过程,同样的条件,数据库负载也是正常的情况下,时快时慢。原因是数据库无法获取临时表的统计信息,导致执行计划会走错。之前写过一个帖子,被临时表坑了,就是用hint/*+ dynamic_sampling(T 10) */来做动态采集,这种解决方案实践证明还是没有很好的解决问题,出现时快时慢的几率只是小了一点。

最优的解决方案是什么呢?

一般我们会选择事务型的临时表,如果你用的是oracle 12c,恭喜你,插入临时表后,直接收集统计信息即可,dbms_stats.gather_table_stats是不会提交事务的。

如果是11g及以下的数据库,会提交事务,表会被清空。

那换成基于会话的临时表,也有问题,weblogic连接池中的session是不会释放的,临时表的数据会不断累积。

最终的解决方案是:用基于会话的统计信息,向临时表中插入数据后,紧接着收集统计信息,在存储过程的末尾truncate表。

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇阿里云Ubuntu12.464位安装docker 下一篇15.有序表查找与线索索引查找

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: