一次关闭绑定变量窥探_optim_peek_user_binds导致的存储过程缓慢故障

本文主要是介绍一次关闭绑定变量窥探_optim_peek_user_binds导致的存储过程缓慢故障,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一个客户联系我,他写了一个存储过程,其中有一条insert into select的sql语句运行非常缓慢,平均处理每天的数据量需要4分钟,而如果单独执行此sql语句,其实很快,大概6s左右即可完成,返回的条数也不多,总共500条左右,希望帮忙优化一下.

1.先看一下正常的执行sql效率和执行计划

此sql非常长,有多个union all连接而成,大概sql如下:

...

我们看到这个sql通过时间字段enter_date进行了限制,取一天的数据,而且时间字段上面有索引,所以直接执行的时候肯定是走索引的,下面是截取的某一段的执行计划:

由于时间字段是非前缀,所以走的是index skip scan.

2.再看一下存储过程中的执行计划

执行存储过程,在后台通过sql_id查看此sql的真实执行计划,这里我们发现了问题:

这里的inp_bill_detail是大表,上面有索引但是却没有走,而是进行了全表扫描,此过程中有多个类似的sql,全部都是大表的全表扫描,所以肯定就非常慢了

那么我们这里就找到了问题所在,相同的一段sql,直接执行和放到存储过程中执行,却有不同的执行计划,过程中的执行计划很差,导致的运行缓慢.

那么这一段看似相同的sql为啥执行计划不一样呢?sql有什么不同吗?

其实很容易就可以看到,在plsql中直接执行的时候,没有使用绑定变量,是直接输入的参数值,而在过程中执行的时候是使用的绑定变量.那么我们这里想到很可能是绑定变量的原因导致的.

oracle中绑定变量窥探,由隐藏参数_optim_peek_user_binds设置,默认为true开启,当开启了绑定变量窥探,在使用绑定变量的时候,oracle内部会自动窥探绑定变量的值,从而选择合适的执行计划.

 一般在oltp环境基本都关闭此参数,防止因为绑定变量的原因导致的执行计划不稳定,检查当前数据库的设置为false:

但是这里明显应该是要开启绑定变量窥探,对查询数据进行限制,执行计划才对.

 

3.解决办法

既然此参数为false而且数据库运行正常,如果冒然修改此参数可能会带来不确定因素,影响其它正常运行的sql,因此建议还是在sql级别进行单独调整.

使用hint在sql级别进行调整:

调整后的sql执行计划如下:

最后经过确认,每天处理的数据的时间由原来的4分钟减少到了4秒,效果明显!

 

这篇关于一次关闭绑定变量窥探_optim_peek_user_binds导致的存储过程缓慢故障的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/695002

相关文章

Window Server创建2台服务器的故障转移群集的图文教程

《WindowServer创建2台服务器的故障转移群集的图文教程》本文主要介绍了在WindowsServer系统上创建一个包含两台成员服务器的故障转移群集,文中通过图文示例介绍的非常详细,对大家的... 目录一、 准备条件二、在ServerB安装故障转移群集三、在ServerC安装故障转移群集,操作与Ser

使用MongoDB进行数据存储的操作流程

《使用MongoDB进行数据存储的操作流程》在现代应用开发中,数据存储是一个至关重要的部分,随着数据量的增大和复杂性的增加,传统的关系型数据库有时难以应对高并发和大数据量的处理需求,MongoDB作为... 目录什么是MongoDB?MongoDB的优势使用MongoDB进行数据存储1. 安装MongoDB

windos server2022的配置故障转移服务的图文教程

《windosserver2022的配置故障转移服务的图文教程》本文主要介绍了windosserver2022的配置故障转移服务的图文教程,以确保服务和应用程序的连续性和可用性,文中通过图文介绍的非... 目录准备环境:步骤故障转移群集是 Windows Server 2022 中提供的一种功能,用于在多个

SpringBoot 整合 Grizzly的过程

《SpringBoot整合Grizzly的过程》Grizzly是一个高性能的、异步的、非阻塞的HTTP服务器框架,它可以与SpringBoot一起提供比传统的Tomcat或Jet... 目录为什么选择 Grizzly?Spring Boot + Grizzly 整合的优势添加依赖自定义 Grizzly 作为

怎么关闭Ubuntu无人值守升级? Ubuntu禁止自动更新的技巧

《怎么关闭Ubuntu无人值守升级?Ubuntu禁止自动更新的技巧》UbuntuLinux系统禁止自动更新的时候,提示“无人值守升级在关机期间,请不要关闭计算机进程”,该怎么解决这个问题?详细请看... 本教程教你如何处理无人值守的升级,即 Ubuntu linux 的自动系统更新。来源:https://

mysql-8.0.30压缩包版安装和配置MySQL环境过程

《mysql-8.0.30压缩包版安装和配置MySQL环境过程》该文章介绍了如何在Windows系统中下载、安装和配置MySQL数据库,包括下载地址、解压文件、创建和配置my.ini文件、设置环境变量... 目录压缩包安装配置下载配置环境变量下载和初始化总结压缩包安装配置下载下载地址:https://d

VUE动态绑定class类的三种常用方式及适用场景详解

《VUE动态绑定class类的三种常用方式及适用场景详解》文章介绍了在实际开发中动态绑定class的三种常见情况及其解决方案,包括根据不同的返回值渲染不同的class样式、给模块添加基础样式以及根据设... 目录前言1.动态选择class样式(对象添加:情景一)2.动态添加一个class样式(字符串添加:情

springboot整合gateway的详细过程

《springboot整合gateway的详细过程》本文介绍了如何配置和使用SpringCloudGateway构建一个API网关,通过实例代码介绍了springboot整合gateway的过程,需要... 目录1. 添加依赖2. 配置网关路由3. 启用Eureka客户端(可选)4. 创建主应用类5. 自定

最新版IDEA配置 Tomcat的详细过程

《最新版IDEA配置Tomcat的详细过程》本文介绍如何在IDEA中配置Tomcat服务器,并创建Web项目,首先检查Tomcat是否安装完成,然后在IDEA中创建Web项目并添加Web结构,接着,... 目录配置tomcat第一步,先给项目添加Web结构查看端口号配置tomcat    先检查自己的to

使用JavaScript操作本地存储

《使用JavaScript操作本地存储》这篇文章主要为大家详细介绍了JavaScript中操作本地存储的相关知识,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以参考一下... 目录本地存储:localStorage 和 sessionStorage基本使用方法1. localStorage