如何解决存储过程中关联临时表时快时慢的情况
来源:互联网 发布:网络晒长腿大赛 编辑:程序博客网 时间:2024/05/20 13:11
调用一个存储过程,同样的条件,数据库负载也是正常的情况下,时快时慢。原因是数据库无法获取临时表的统计信息,导致执行计划会走错。之前写过一个帖子,被临时表坑了,http://blog.csdn.net/stevendbaguo/article/details/39964807,就是用hint/*+ dynamic_sampling(T 10) */来做动态采集,这种解决方案实践证明还是没有很好的解决问题,出现时快时慢的几率只是小了一点。
最优的解决方案是什么呢?
一般我们会选择事务型的临时表,如果你用的是oracle 12c,恭喜你,插入临时表后,直接收集统计信息即可,dbms_stats.gather_table_stats是不会提交事务的。
如果是11g及以下的数据库,会提交事务,表会被清空。
那换成基于会话的临时表,也有问题,weblogic连接池中的session是不会释放的,临时表的数据会不断累积。
最终的解决方案是:用基于会话的统计信息,向临时表中插入数据后,紧接着收集统计信息,在存储过程的末尾truncate表。
0 1
- 如何解决存储过程中关联临时表时快时慢的情况
- 临时表操作的一些见解(解决了我在存储过程中使用临时表的困惑)
- 临时表操作的一些见解(解决了我在存储过程中使用临时表的困惑)
- 临时表的存储过程
- Oracle存储过程中使用临时表的替代方案
- Oracle存储过程中使用临时表的替代方案
- Oracle存储过程中临时表的使用技巧
- 在存储过程中使用临时表
- 存储过程中使用临时表.
- 在存储过程中创建临时表
- mysql存储过程中使用临时表
- Oracle存储过程中使用临时表
- Oracle存储过程中使用临时表
- Oracle存储过程中使用临时表
- Oracle存储过程中使用临时表
- Oracle存储过程中使用临时表
- oracle存储过程中使用临时表
- Mysql存储过程中使用临时表
- 常用网页使用js技巧收集(200多个)经典
- 用反射通过字符串获取窗体
- boost_1.47在VS2010下的安装
- android开发中积累的小知识(转)
- LeetCode --- 81. Search in Rotated Sorted Array II
- 如何解决存储过程中关联临时表时快时慢的情况
- malloc、calloc、realloc,alloca 的区别
- ctags和vim的安装和使用详解
- log4j设置
- Hadoop 2.6.0 Configuration源码分析
- 从驱动层将USB3.0转换为USB2.0
- 【.Net码农】WPF组件开发之组件的基类
- selenium IDE下载
- C语言实现的一个简单的HTTP程序