广告
返回顶部
首页 > 资讯 > 数据库 >Oracle SQL 语句高版本分析
  • 837
分享到

Oracle SQL 语句高版本分析

2024-04-02 19:04:59 837人浏览 薄情痞子
摘要

oraclesql 语句高版本分析1.     何为高版本每次执行一条SQL语句时,如果其对应的当前已经存在于library cache里的一个父游标下的各

oraclesql 语句高版本分析

1.     何为高版本

每次执行一条SQL语句时,如果其对应的当前已经存在于library cache里的一个父游标下的各个子游标都不能被该SQL语句重新使用(即共享),则会产生一个新的子游标,此时就会在V$SQL_SHARED_CURSOR里新增一行,分别描述该SQL语句不能使用当前已经存在的各个子游标的原因。当然一个父游标下的第一个子游标产生时也会在该视图上新增一行,只是各个该视图上的描述原因的列的值都为N,在V$SQL_SHARED_CURSOR行数就是此SQL语句执行的版本数,也就种类数

2.     怎样才会产生高版本

    A.       ORACLE使用子游标去区分一个不能被共享的SQL,因为虽然SQL相同,但是SQL所指向的对象使不同的。也就是说,这些SQL的父游标都是一样的,HASH_VALUE值都相同。例如,数据库有三个表T,有这样一个语句,select *from T,由于每个T都被不同的对象使用或是用户使用,而在数据库级别,这些语句都是一样的,HASH_VALUE都相同,但是他们的子游标就不同了,这就会产生High Version Counts,由于HASH_VALUE相同,持有LATCH会不放,所以当PARSE的时候就会产生LATCH FREE。这是产生High Version的一个方面;

 

  B.       对于字符类型的字段,进行绑定变量的时候,第一次会使用32字节的BUFFER,如果该值小于32字节的话,第二次执行这个SQL的时候,如果小于32字节,那么可以共享这个CURSOR,如果大于,就无法共享,原因就是BIND_MISMATCH,此时会产生一个子CURSOR,同时分配大于32字节的BIND BUFFER

 

  C.       对于NULL值,因为oracleNULL 这个值表示什么都不是,如果变量为NULL则也会新一个子游标。

 

3.     有何后果

发现Oracle因为某些原因不可重用这些SQL。当这类SQL执行次数很多,就会占用大量的shared pool,引起library cache pinlibrary cache 的等待事件,严重引起主机挂起。

 

 

4.     解决方法

 

A.  数据库升级

l  版本升级( 11.2.0.4)升级包,但分险较大,周期长,需要测试验证,搭建测试环境,需要更新文件有以下文件

p13390677_112040_linux-x86-64_1of7.zip

p13390677_112040_Linux-x86-64_2of7.zip

p13390677_112040_Linux-x86-64_3of7.zip

  • 定时清 ALTERSYSTEM FLUSH SHARED_POOL;


B.  程序修改方法

l 程序对字符变量设定固定大小

l 对NULL值特别处理,使用不同的InSert 语句

l Insert 操作时防止同一主键同时插入。


 

  1. 5.     实例分析

 

select sql_id,count(0) from gv$sql groupby sql_id orderby2desc;

 

Oracle SQL 语句高版本分析

 

version_count对应子游标数:

select sql_id,sql_text,executions,version_count fromgv$sqlarea where sql_id='6hk042t0trr1t';

Oracle SQL 语句高版本分析

 

selectsql_id,child_number,sql_text,optimizer_mode,plan_hash_value from gv$sql where sql_id='6hk042t0trr1t';

Oracle SQL 语句高版本分析

 

查子游标不能共享(失效的原因,如optimizer_mode_mismatch,BIND_MISMATCH等原因)的原因:

selectchild_number,optimizer_mode_mismatch,BIND_MISMATCH  from gv$sql_shared_cursor where sql_id='6hk042t0trr1t'orderby child_number;

Oracle SQL 语句高版本分析

 

绑定失效的时候,查看一下每次绑定变量的值:

selectposition,LAST_CAPTURED,datatype_string,value_string fromgv$sql_bind_capture where sql_id='6hk042t0trr1t';

 

Oracle SQL 语句高版本分析

绑定变量字段长度变化的情况:

select * from dba_hist_sqlbind where sql_id='6hk042t0trr1t';

 

 


您可能感兴趣的文档:

--结束END--

本文标题: Oracle SQL 语句高版本分析

本文链接: https://www.lsjlt.com/news/44557.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Oracle SQL 语句高版本分析
    OracleSQL 语句高版本分析1.     何为高版本每次执行一条SQL语句时,如果其对应的当前已经存在于library cache里的一个父游标下的各...
    99+
    2022-10-18
  • 库表分析-sql语句
    SET FOREIGN_KEY_CHECKS=0; -- ------------------------------ Table structure for car-- ---------------------------- DROP...
    99+
    2016-06-09
    库表分析-sql语句 数据库入门 数据库基础教程 数据库 mysql
  • Java不同版本的Switch语句实例分析
    这篇文章主要讲解了“Java不同版本的Switch语句实例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java不同版本的Switch语句实例分析”吧!旧的Java Switch语句sw...
    99+
    2023-07-02
  • 30分钟入门Oracle sql语句
    SELECT *|{[DISTINCT] column|expression [alias],...}FROM    table;SELECT * FROM  ...
    99+
    2022-10-18
  • Oracle中sql语句(+)符号代表连接的示例分析
    小编给大家分享一下Oracle中sql语句(+)符号代表连接的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!oracle...
    99+
    2022-10-18
  • Oracle高资源消耗SQL语句定位
    Oracle高资源消耗SQL语句定位 http://www.ecdoer.com/post/oracle-highcost-sql-locate.html Oracle SQL语句...
    99+
    2022-10-18
  • ORACLE SQL语句优化技术要点解析
    操作符优化: IN 操作符   用IN写出来的SQL的优点是比较容易写及清晰易懂,这比较适合现代软件开发的风格。   但是用IN的SQL性能总是比较低的,从ORACLE执行的步骤来分析用IN的SQL与...
    99+
    2022-10-18
  • 对SQL语句进行分析和优化
    安装和查看ORACLE执行计划ORACLE在执行SQL语句时使用的步骤的集合叫做执行计划前起条件:    在目录:$ORACLE_HOME/RDBMS/ADMIN目录下的执行u...
    99+
    2022-10-18
  • MySQL 语句分析及sql进程查看
    在 my.cnf 文件中配置好:slow_query_log=1slow_query_log_file=mysql.slowlong_query_time=10即可记录超过默认的 10s 执行时间的 SQL...
    99+
    2022-10-18
  • sql查询语句之平均分、最高最低分及排序语句
    目录前言数据表数据查询各课程的考试学生人数查询各科成绩最高分和最低分查询男生、女生人数查询平均成绩查询平均成绩大于70分学生的学号和平均成绩查询学生考试参与考试课程数量查询考试两门以...
    99+
    2022-11-13
  • MySQL数据库SQL语句高级操作实例代码分析
    本文小编为大家详细介绍“MySQL数据库SQL语句高级操作实例代码分析”,内容详细,步骤清晰,细节处理妥当,希望这篇“MySQL数据库SQL语句高级操作实例代码分析”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一...
    99+
    2023-07-02
  • SQL语句解读服务的示例分析
    SQL语句解读服务的示例分析,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。今天主要分享一个有趣的SQL语句解读服务,支持高亮显...
    99+
    2022-10-19
  • MySQL中SQL语句优化的示例分析
    这篇文章主要介绍MySQL中SQL语句优化的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!sql如下:sql强制用了into_time索引# Time: 2017-02-14...
    99+
    2022-10-18
  • sql语句执行缓慢的原因分析
    这篇文章主要介绍“sql语句执行缓慢的原因分析”,在日常操作中,相信很多人在sql语句执行缓慢的原因分析问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”sql语句执行缓慢的原因...
    99+
    2022-10-18
  • SQL语句中JOIN的用法场景分析
    记录:256 写SQL最高境界:SELECT * FROM 表名。当然这是一句自嘲。探究一下SQL语句中JOIN的用法,直到经历这个场景,变得想验证一下究竟。 一、场景 把关...
    99+
    2022-11-12
  • Mysql中Sql语句注释的示例分析
    这篇文章主要介绍了Mysql中Sql语句注释的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。MySQL的SQL语句里面是可以加注释的...
    99+
    2022-10-18
  • MySQL中SQL语句分析与查询优化的示例分析
    这篇文章主要为大家展示了“MySQL中SQL语句分析与查询优化的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“MySQL中SQL语句分析与查询优化的示例...
    99+
    2022-10-18
  • 简单的创建数据库sql语句分析
    今天小编给大家分享的是简单的创建数据库sql语句分析,相信很多人都不太了解,为了让大家更加了解,所以给大家总结了以下内容,一起往下看吧。一定会有所收获的哦。创建数据库的sql语句是“CREATE DATAB...
    99+
    2022-10-18
  • 怎么对MySQL SQL语句性能进行分析
    本篇文章为大家展示了怎么对MySQL SQL语句性能进行分析,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。MySQL SQL语句性能分析 set prof...
    99+
    2022-10-18
  • MySQL如何利用profiling分析SQL查询语句
    查看profiling是否开启: mysql> select @@profiling; +-------------+ | @@profiling | +-------------+ | &...
    99+
    2022-10-18
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作