首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Oracle SQL调优之绑定变量用法简介

Oracle的游标Cursor原理简介,再介绍oracle绑定变量 介绍绑定变量之前,先介绍SQL执行过程和硬解析的概念: 执行sql的过程,会将sql的文本进行hash运算,得到对象的hash值,...方法就是用绑定变量的方法 二、绑定变量典型用法 2.1、在SQL绑定变量 绑定变量的典型用法就是用 :variable_name的形式,variable_name是自定义的变量名称,variabl_name...FROM v$sqlarea order BY disk_reads DESC) where ROWNUM < 10; 2.2、在PL/SQL中使用绑定变量 /...; end; / 所以绑定变量pl/sql里的核心语法为: execute immediate [sql语句] using [变量] 2.3、PL/SQL批量绑定变量 例子来自《基于Oracle的...(); 批量绑定变量写法: 此例子来自《基于OracleSQL优化》一书: String vc_sql = 'update t_emp set sal = ?

1.2K20

Oracle 绑定变量窥探

影响的版本:Oracle 9i, Oracle 10g     对于绑定变量列中的特殊值或非均匀分布列上的绑定变量会造成非高效的执行计划被选择并执行。        ...我们可以看出,Bind     peeking并不能最终解决不同谓词导致选择不同执行计划的问题,它只能让SQL第一次执行的时候,执行计划选择更加准确,并不能帮助OLAP     系统解决绑定变量导致执行计划选择错误的问题...这也是OLAP不应该使用绑定变量的一个原因。         更确切地说,绑定变量窥探是在SQL解析的物理阶段,查询优化器将会窥探绑定变量的值并将其作为字面量来使用。...即ORACLE首次解析     SQL时会将变量的真实值代入产生执行计划,后续对所有使用该绑定变量SQL语句都采用首次生存的执行计划。如此这般?那性能究竟如何?    ...在Oracle 11g 中,自适 应特性从一定程度解决了绑定变量窥探所导致的问题。

1.7K30
您找到你想要的搜索结果了吗?
是的
没有找到

Oracle SQL调优系列之绑定变量用法简介

最近在看《基于OracleSQL优化一书》,并做了笔记,作者的个人博客:http://www.dbsnake.net/ 文章目录 一、SQL执行过程简介 二、绑定变量典型用法 2.1、在SQL绑定变量...2.2、在PL/SQL中使用绑定变量 2.3、PL/SQL批量绑定变量 2.4、Java代码里使用绑定变量 一、SQL执行过程简介 继上一篇博客Oracle的cursor学习笔记:Oracle的游标Cursor...原理简介,再介绍oracle绑定变量 介绍绑定变量之前,先介绍SQL执行过程和硬解析的概念: 执行sql的过程,会将sql的文本进行hash运算,得到对象的hash值,然后拿hash值,去Hash Buckets...[sql语句] using [变量] 2.3、PL/SQL批量绑定变量 例子来自《基于OracleSQL优化》一书,要实现的的是批量绑定变量,fetch关键字,将empno大于7900的职员信息打印出来...(); 批量绑定变量写法: 此例子来自《基于OracleSQL优化》一书: String vc_sql = 'update t_emp set sal = ?

64520

Oracle优化09-绑定变量

如果没有找到,Oracle会认为这是一条新的SQL, 将会按照下面的顺序来执行: ---- 1 .语法分析 SQL 是否符Oracle规定的语法,如果有语法错误,则向用户抛出错误信息 ?...---- 绑定变量 what ,why 绑定变量就起本质而言就是说把本来需要Oracle做硬分析的SQL变成了软分析,以减少Oracle花费在SQL解析上的时间和资源。...---- 是否采用绑定变量在资源消耗上对比 下面我们来对下同一条SQL被执行10000次,绑定变量和非绑定变量在资源消耗上的情况 采用绑定变量 打开SQL_TRACE Connected to Oracle...---- 结论 OLAP系统完全没有必要设置绑定变量那样只会带来负面的影响,比如导致SQL选择了错误的执行计划,让Oracle对每条SQL做hard parse ,确切知道谓词条件的值,这对执行计划的选择至关重要...bind peeking 并不能最终解决不同谓词导致不同执行计划的问题,它只能让SQL第一次执行的时候,执行计划更加准确,并不能帮助OLAP系统解决绑定变量导致执行计划选择错误的问题,所以,OLAP依然不应该使用绑定变量

62010

Oracle-绑定变量binding variable解读

SQL 绑定变量栗子 在Java中的使用绑定变量 实际工作中的应用 总结 绑定变量概述 Oracle 中,对于一个提交的sql语句,存在两种可选的解析过程, 一种叫做硬解析,一种叫做软解析....如果在共享池中没有找到相同Hash 值的SQLoracle 会认为这是一条新的SQL, 会进行硬解析。 而唯一使得oracle 能够重复利用执行计划的方法就是采用绑定变量。...绑定变量的本质就是本来需要做Oracle 硬解析的SQL 变成软解析,以减少ORACLE 花费在SQL解析上的时间和资源。...绑定变量是在通常情况下能提升效率,非正常的情况如下: 在字段(包括字段集)建有索引,且字段(集)的集的势非常大(也就是有个值在字段中出现的比例特别的大)的情况下,使用绑定变量可能会导致查询计划错误,因而会使查询效率非常低...---- 绑定变量详解 ---- 绑定变量使用限制条件 为了不重复解析相同的SQL语句,在第一次解析之后, ORACLESQL语句存放在内存中.这块位于系统全局区域SGA(system global

1.8K10

【DB笔试面试581】在Oracle中,绑定变量是什么?绑定变量有什么优缺点?

♣ 题目部分 在Oracle中,绑定变量是什么?绑定变量有什么优缺点? ♣ 答案部分 绑定变量这节的内容较多,下面给出这节涉及到的关系图: ?...当表的列上存在数据倾斜(表上的数据非均匀分布)时,Oracle可能会提供错误的执行计划,从而使得非高效的执行计划被使用。...在PL/SQL中通过批量绑定的方式使用绑定变量PL/SQL中的“批量绑定”是一种优化后的使用绑定变量的方式。...真题1、下面有关SQL绑定变量的描述中,错误的是() A、绑定变量是指在SQL语句中使用变量,改变变量的值来改变SQL语句的执行结果 B、使用绑定变量,可以减少SQL语句的解析,能减少数据库引擎消耗在SQL...所以,选项B错误。 对于选项C,使用绑定变量,减少解析次数,提高了编程效率和可靠性。所以,选项C错误。 对于选项D,使用绑定变量,查询优化器不知道具体的值,所以,其执行计划也不真实。

2.5K20

JDBC错误:java.sql.SQLException: ORA-01008: 并非所有变量都已绑定「建议收藏」

: ORA-01008: 并非所有变量都已绑定 at oracle.jdbc.dbaccess.DBError.throwSqlException(DBError.java:134) at oracle.jdbc.ttc7....TTIoer.processError(TTIoer.java:289) at oracle.jdbc.ttc7.Oall7.receive(Oall7.java:573) at oracle.jdbc.ttc7...:1093) at oracle.jdbc.driver.OracleStatement.executeNonQuery(OracleStatement.java:2047) at oracle.jdbc.driver.OracleStatement.doExecuteOther...(CourseTimeInfoDao.java:60) Java中执行sql语句总是报这个错误,在网上查了一些原因,都说是因为sql语句标点符号有错误,检查了很长时间没有找到符号错误。...把sql拿到PL/SQL中执行可以通过。最后发现在result =pstm.executeUpdate(sql); 这句中多加了sql ,在执行时是不需要传sql的,找了半天的错误,原来在这里。

69120

执行计划 - Oracle谓词越界与绑定变量窥探

但在真实环境中,总会受到一些因素的影响,今天我们来分析谓词越界和绑定变量窥探对SQL执行计划的影响。...结果排查发现客户在导入数据后并未重新收集统计信息,SQL使用绑定变量,窥探的变量刚好是越界,导致SQL第一次硬解析生成的执行计划走错。再加上10G的库导致接下来的执行计划直接沿用内存中的执行计划。...,字段上有直方图信息,在10g里面也会由于绑定变量窥探从而使SQL大部分变量的执行计划走错。...另外第一个等值查询的SQL如果使用绑定变量,如果第一次查询变量值id2=1,那么SQL会走索引范围扫,之后该SQL都会沿用这个执行计划,而大多数大多数情况下是查id2=100或在id2=200,理论上应该走索引快速全扫...这里需要注意的是,变量窥探一般情况下在select语句使用绑定变量都会去窥探,与字段上有无索引、直方图信息无关,虽然个人认为在没有直方图和索引的情况下意义不大,但是oracle都会去窥探变量值然后根据变量值生成执行计划

1.5K30

绑定变量及其优缺点

绑定变量Oracle解决硬解析的首要利器,能解决OLTP系统中library cache的过度耗用以提高性能。然刀子磨的太快,使起来锋利,却容 易折断。...本文讲述了绑定变量的使用方法,以及绑定变量的优缺点、使用场合。 一、绑定变量     提到绑定变量,就不得不了解硬解析与软解析。...绑定变量       首先其实质是变量,有些类似于我们经常使用的替代变量,替代变量使用&占位符,只不过绑定变量使用:       替代变量使用时为 &variable_para,相应的绑定变量则为.../sql代码中,Oracle实现自动变量自动绑定,执行了30次的insert操作,但oracle认为每次执行的语句都是一样的 /*****************************...> get get_sal.sql -->下面的pl/sql中使用了绑定变量

1.4K20

【DB笔试面试583】在Oracle中,什么是绑定变量分级?

♣ 题目部分 在Oracle中,什么是绑定变量分级?...♣ 答案部分 绑定变量分级(Bind Graduation)是指OraclePL/SQL代码中会根据文本型绑定变量的定义长度而将这些文本型绑定变量分为四个等级,不同等级分配的内存大小不同,如下表所示...需要注意的是,绑定变量分级仅适用于文本型的绑定变量Oracle不会对数值(NUMBER)型的绑定变量绑定变量分级。...如果在PL/SQL代码中使用了文本型绑定变量,只要其SQL文本中文本型绑定变量的定义长度发生了变化,那么Oracle为这些绑定变量所分配的内存空间的大小也可能会随之发生变化,而一旦Oracle为这些绑定变量所分配的内存空间的大小发生了变化...所以这里Oracle在执行范例PL/SQL代码1、2、3时每次都是硬解析,但在执行范例PL/SQL代码4和5时会用软解析/软软解析,因为范例PL/SQL代码4和5可以重用之前执行的范例PL/SQL代码3

68210

Oracle-Soft ParseHard ParseSoft Soft Parse解读

当发布一条DML SQLPL/SQL命令时,Oracle会自动寻找该命令是否存在于共享池中来决定对当前的语句使用硬解析或软解析。...绑定变量要求变量名称,数据类型以及长度是一致,否则无法使用软解析 绑定变量(bindvariable)是指在DML语句中使用一个占位符,即使用冒号后面紧跟变量名的形式,如下   select * from...Warning: Procedure created with compilation errors 当有错误时,可以通过show error来显示错误 SQL> show error Errors...每一条都是一个硬解析,也耗时了3.7S , 使用绑定变量耗时0.4S….. 在未使用绑定变量的情形下,不论是解析次数,闩使用的数量,队列,分配的内存,库缓存,行缓存远远高于绑定变量的情况。...3.尽可能的使用绑定变量来避免硬解析

2.2K20

【DB笔试面试389】在Oracle中,什么是绑定变量窥探?

Q 题目 在Oracle中,什么是绑定变量窥探?...A 答案 目标SQL若不使用绑定变量,则当具体输入值一旦发生了变化,目标SQLSQL文本就会随之发生变化,这样Oracle就能很容易地计算出对应Selectivity和Cardinality的值,进而据此来选择执行计划...对于使用了绑定变量的目标SQL而言,Oracle可以选择如下两种方法来决定其执行计划: l 使用绑定变量窥探(Bind Peeking)。...绑定变量窥探的优缺点如下所示: ① 优点:当绑定变量窥探被启用后,每当Oracle以硬解析的方式解析使用了绑定变量的目标SQL时,Oracle都会实际窥探(Peeking)一下对应绑定变量的具体输入值,...因为有了绑定变量窥探,所以,Oracle在计算目标SQL的WHERE条件的Selectivity和Cardinality的值时,就可以避免使用默认的可选择率,这样就有更大的可能性能得到该SQL准确的执行计划

83320

【DB笔试面试445】Oracle中的异常可以分为哪几类?

(3)当异常处理结束后,Oracle就将处理权交给调用者。结束PL/SQL块的运行。 Oracle将异常分为预定义异常、非预定义异常和自定义异常三种。...预定义异常用于处理常见的Oracle错误,对这种异常情况的处理,无需在程序中定义,由Oracle自动将其触发。它们全部放在PL/SQL自带的标准包中,这样程序员就无需再次定义了。...ORA-06502 VALUE_ERROR 赋值操作,变量长度不足,触发该异常 ORA-06504 ROWTYPE_MISMATCH 宿主游标变量PL/SQL变量有不兼容行类型 ORA-06531...使用预定义异常只能处理系统预定义的20多个Oracle错误,而当使用PL/SQL开发应用程序时,可能会遇到其它的一些Oracle错误。例如,在PL/SQL块中执行DML语句时,违反了约束规定等等。...3 PRAGMA EXCEPTION_INIT(FK_EXCEPTION, -2292); --将该变量和指定的错误绑定 4 V_ERROR_CODE NUMBER;

1.7K10

Oracle绑定变量和审计功能影响性能吗?Python告诉你

墨墨导读:SQL中使用绑定变量,以及开通审计功能对数据库影响有多大?本文来自读者投稿,作者用Python进行了一番测试,欢迎评论区交流互动。...一、概述 dba在工作中避不开的两个问题,sql使用绑定变量到底会有多少的性能提升?数据库的审计功能如果打开对数据库的性能会产生多大的影响?最近恰好都碰到了,索性做个实验。...使用绑定变量对性能的影响 a....使用绑定变量 对库进行重启,目的是清空数据库内的所有缓存,避免对实验结果产生干扰 SQL> startup force; SQL> drop table yang.testtb purge; SQL>...不使用绑定变量 对库进行重启 SQL> startup force; SQL> drop table yang.testtb purge; SQL> create table yang.testtb as

88710

java批量插入数据库之写绑定变量

最近查到关于sql批量写入和绑定变量的问题,看到了很多好的帖子,再次进行总结 数据库在执行SQL语句时会首先解析SQL语句,解析又分为硬解析与软解析。...说到硬解析和软解析,就不能不说一下Oraclesql的处理过程。...当你发出一条sql语句交付Oracle,在执行和获取结果前,Oracle对此sql将进行几个步骤的处理过程: 1、语法检查(syntax check)   检查此sql的拼写是否语法。...认识绑定变量:   绑定变量是为了减少解析,比如你有个语句这样的:   select aaa,bbb from ccc where ddd=eee;   如果经常通过改变eee这个谓词赋值来查询,...所以上文的:x更多的是在Oracle中的本身里面,对比两者可以发现,一种是单纯的问号,一种是用变量名,当赋值的变量是重复的时候,用后者可以避免重复书写,但后者由于是变量名,也会导致书写错误, 在近期研究中发现

30220

【DB笔试面试584】在Oracle中,如何得到已执行的目标SQL中的绑定变量的值?

♣ 题目部分 在Oracle中,如何得到已执行的目标SQL中的绑定变量的值?...♣ 答案部分 当Oracle解析和执行含有绑定变量的目标SQL时,如果满足如下两个条件之一,那么该SQL中的绑定变量的具体输入值就会被Oracle捕获: l 当含有绑定变量的目标SQL以硬解析的方式被执行时...l 当含有绑定变量的目标SQL以软解析或软软解析的方式重复执行时,Oracle在默认情况下至少得间隔15分钟才会捕获一次。...只会捕获那些位于目标SQL的WHERE条件中的绑定变量的具体输入值,而对于那些使用了绑定变量的INSERT语句,不管该INSERT语句是否是以硬解析的方式执行,Oracle始终不会捕获INSERT语句的...查询视图V$SQL_BIND_CAPTURE或V$SQL可以得到已执行目标SQL绑定变量的具体输入值。

3K40

Oracle 硬解析与软解析

一、SQL语句的执行过程 当发布一条SQLPL/SQL命令时,Oracle会自动寻找该命令是否存在于共享池中来决定对当前的语句使用硬解析或软解析。...绑定变量要求变量名称,数据类型以及长度是一致,否则无法使用软解析 绑定变量(bind variable)是指在DML语句中使用一个占位符,即使用冒号后面紧跟变量名的形式,如下 select *...使用绑定变量的例子(参照了TOM大师的Oracle 9i&10g编程艺术) scott@ASMDB> create table tb_test(col int); --创建表tb_test scott...由上面的示例可知,在未使用绑定变量的情形下,不论是解析次数,闩使用的数量,队列,分配的内存,库缓存,行缓存远远高于绑定 变量的情况。因此尽可能的使用绑定变量避免硬解析产生所需的额外的系统资源。...3.尽可能的使用绑定变量来避免硬解析。

87030
领券