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

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

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

3K40

Oracle 动态SQL「建议收藏」

Oracle 动态SQL 一、动态SQL的简介 1、定义 静态SQL是指直接嵌入到PL/SQL块中的SQL语句。 动态SQL是指运行PL/SQL块是动态输入的SQL语句。...2、适用范围 如果在PL/SQL块中需要执行DDL语句(create,alter,drop等)、DCL语句(grant,revoke等)或更加灵活的SQL语句,需要用到动态SQL。...SQL语句或PL/SQL块的字符串变量; define用于指定存放单位查询结果的变量; bind_name(in)用于指定存放被传递给动态SQL值得变量; bind_name(out)用于指定存放动态...SQL中使用bulk子句 1、概述 在动态SQL中使用BULK子句为9i新增特征,BULK子句实际是动态SQL语句将变量绑定为集合元素, 集合类型可以是PL/SQL所支持的索引表、嵌套表和VARRAY...1)、概述 使用forall语句,可允许在动态SQL语句中为输入变量同时提供多个数据, 但forall语句只适用于动态的insert\update\delete语句, 不适用于动态select

1.6K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    PLSQL --> 动态SQL的常见错误

    := 'DECLARE ' || --声明一个PL/SQL块,存放到变量plsql_block中 ' v_date DATE; ' || 'BEGIN ' || ' SELECT SYSDATE...--执行动态SQL块 USING v_empno RETURNING INTO v_new_sal; --使用RETURNING子句将结果存放到变量v_new_sal中 DBMS_OUTPUT.PUT_LINE...的常见错误 1.使用动态DDL时,不能使用绑定变量 下面的示例中,在创建表示,使用了绑定变量:dno,在执行的时候收到了错误信息。...应该将绑定变量与原动态SQL使用连接符进行连接。 2.不能使用schema对象作为绑定参数,将schema对象与原动态SQL使用连接符进行连接。 3.动态SQL块不能使用分号结束(;)。...8.动态SQL中RETURNING INTO返回DML操作的结果,对于SELECT查询返回的结果,在执行EXECUTE IMMEDIATE时,直接使用INTO子句来传递。

    2.2K20

    【DB笔试面试806】在Oracle中,如何查找未使用绑定变量的SQL语句?

    ♣ 题目部分 在Oracle中,如何查找未使用绑定变量的SQL语句?...换句话说,如果两个SQL语句除了字面量的值之外都是相同的,它们将拥有相同的FORCE_MATCHING_SIGNATURE,这意味着如果为它们提供了绑定变量或者CURSOR_SHARING,它们就成了完全相同的语句...⊙ 【DB笔试面试585】在Oracle中,什么是常规游标共享?⊙ 【DB笔试面试584】在Oracle中,如何得到已执行的目标SQL中的绑定变量的值?...⊙ 【DB笔试面试583】在Oracle中,什么是绑定变量分级?⊙ 【DB笔试面试582】在Oracle中,什么是绑定变量窥探(下)?...⊙ 【DB笔试面试582】在Oracle中,什么是绑定变量窥探(上)?⊙ 【DB笔试面试581】在Oracle中,绑定变量是什么?绑定变量有什么优缺点?

    6.4K20

    PLSQL --> 动态SQL

    静态SQL为在执行前编译,一次编译,多次运行。动态SQL同样在执行前编译,但每次执行需要重新编译。 静态SQL可以使用相同的执行计划,对于确定的任务而言,静态SQL更具有高效性。...d.使用系统提供的PL/SQL包DBMS_SQL来实现动态SQL,关于该方式请参考后续博文。...INTO bind_argument1, bind_argument2, ...] 1.语法描述 dynamic_SQL_string:存放指定的SQL语句或PL/SQL块的字符串变量 defined_variable1...d.当执行SQL时,其尾部不需要使用分号,当执行PL/SQL 代码时,其尾部需要使用分号。 f.动态SQL中的占位符以冒号开头,紧跟任意字母或数字表示。...CLOSE cursor_variable; 2.使用游标变量处理查询多行结果集 下面的示例中,首先定义了一个游标类型,接下来定义游标变量,以及存放结果集的变量,动态查询语句将获得多个结果集。

    2.2K10

    Oracle优化09-绑定变量

    良好的变量绑定会使OLTP系统数据库中的SQL执行的飞快,内存效率极高。 不绑定变量有可能会使OLTP数据库不堪负重,资源被SQL解析严重消耗,系统显得缓慢。...在介绍绑定变量之前,我们需要知道SQL究竟是如何被执行的?...---- 是否采用绑定变量在资源消耗上对比 下面我们来对下同一条SQL被执行10000次,绑定变量和非绑定变量在资源消耗上的情况 采用绑定变量 打开SQL_TRACE Connected to Oracle...从trace文件中可以看到,在fetch阶段,全表扫描读取了42093多个数据块,而走索引的,在fetch阶段,仅仅读取了308个数据块。...这是因为在OLAP系统中,SQL硬分析的代价是可以忽略的,系统的资源基本上是用于做大的SQL查询,和查询比较起来,SQL解析消耗的资源显然微不足道,所以得到一个最优的执行计划变得尤为重要 在OLAP系统上

    67510

    使用 DBMS_PROFILER 定位 PLSQL 瓶颈代码

    而对于PL/SQL代码而言,既有SQL代码,又有PL/SQL代码,仅仅使用10046事件是远远不够的,因为可能SQL时间很短,而整个包或过程执行时间N久,而且包或过程中又嵌套有其他包,过程,函数。...尽管没有工具可以直接作用于PL/SQL代码进行优化,但借助于PL/SQL PROFILER来定位你的代码块中哪些部分是性能瓶颈就已经达到了事半功倍的效果。...本文首先描述了安装PROFILER,接下给出在PL/SQL块中使用字面量与绑定变量时定义瓶颈块以及对比的情形,最后部分列出一些相关脚本。      ...本文描述中涉及到的相关参考 绑定变量及其优缺点 Oracle 硬解析与软解析 Oracle 绑定变量窥探 SQL Tuning Advisor(STA) 到底做了什么?...对于这个事例仅仅是演示定位瓶颈代码,并改用绑定变量以提高性能,对于其他情形,具体的如何修改瓶颈代码应具体分析 4、示例中用到的脚本 a、chk_profile.sql --file_name: chk_profile.sql

    76710

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

    ♣ 题目部分 在Oracle中,什么是绑定变量分级?...需要注意的是,绑定变量分级仅适用于文本型的绑定变量,Oracle不会对数值(NUMBER)型的绑定变量做绑定变量分级。...,那么该SQL之前存储在Child Cursor中的解析树和执行计划就不能被重用了。...所以这里Oracle在执行范例PL/SQL代码1、2、3时每次都是硬解析,但在执行范例PL/SQL代码4和5时会用软解析/软软解析,因为范例PL/SQL代码4和5可以重用之前执行的范例PL/SQL代码3...通过上述示例可以看出:为了避免不必要的硬解析,在PL/SQL代码中处理带文本型绑定变量的目标SQL时,应该将这些文本型绑定变量的定义长度保持在同一个等级,当然,这里最好是定义成一个统一的长度,比如VARCHAR2

    72010

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

    绑定变量通常出现在SQL文本中,用于替换WHERE或VALUES子句中的具体值。 绑定变量的优点如下所示: ① 可以在库缓存(Library Cache)中共享游标,避免硬解析以及与之相关的额外开销。...增长的时间主要耗费在执行目标SQL时对每一个绑定变量都用其实际的值来替换(这个过程就是所谓的绑定变量值替换),目标SQL的SQL文本中的绑定变量的个数越多,这个替换过程所耗费的时间就越长,该SQL总的执行时间也就越长...scott.emp where empno=:v_empno;--使用绑定变量 --② 在PL/SQL中,有如下几种用法: -----a.在静态SQL中使用绑定变量: DECLARE V_NAME...在PL/SQL中通过批量绑定的方式使用绑定变量。 PL/SQL中的“批量绑定”是一种优化后的使用绑定变量的方式。...真题1、下面有关SQL绑定变量的描述中,错误的是() A、绑定变量是指在SQL语句中使用变量,改变变量的值来改变SQL语句的执行结果 B、使用绑定变量,可以减少SQL语句的解析,能减少数据库引擎消耗在SQL

    2.7K20

    PLSQL --> 动态SQL调用包中函数或过程

    动态SQL主要是用于针对不同的条件或查询任务来生成不同的SQL语句。最常用的方法是直接使用EXECUTE IMMEDIATE来执行动态SQL语句字符串或字符串变量。...cascade=>true) PL/SQL procedure successfully completed. 2、动态SQL调用包中过程正确的调用方法 --如下面这段plsql代码,我们在原代码的基础上增加了...begin ..与end部分后,该plsql块被成功执行 --注,字符拼接的plsql块中,end; 之后不需要使用斜杠“/” scott@USBO> DECLARE 2 v_sql VARCHAR2...end; PL/SQL procedure successfully completed. 3、动态SQL调用包中过程带变量的情形 --下面这个示例中拼接的字串中,调用了声明中的变量 --下面给出了错误提示...c、可以拼接sql到变量,也可以直接将动态sql紧跟在EXECUTE IMMEDIATE,个人更倾向于使用前者

    1.5K20

    Oracle PLSQL基础语法学习15:静态表达式

    这个表达式在编译时可以确定其值的表达式,即它不包括字符比较、变量或函数调用,在运行时是不可改变的,常常在PL/SQL中用于初始化变量、常量、参数等。.../SQL代码创建了一个名为my_debug的包,其中包含两个静态常量debug和trace,类型为BOOLEAN,并在其值上分别定义为TRUE,用于控制多个PL/SQL单元中的调试和跟踪。...IF指令用于测试编译时常量的值,如果值为TRUE,则执行THEN指定的代码块,否则执行$ELSE指定的代码块。...在存储过程的主体中,使用 EXECUTE IMMEDIATE 语句来执行了一个 SQL 查询,查询的是名为 table1 的表的所有数据。...在存储过程的主体中,使用 EXECUTE IMMEDIATE 语句来执行了一个 SQL 查询,查询的是名为 table1 的表的所有数据。

    19450

    绑定变量及其优缺点

    凡事皆有利弊二性,因地制宜,因时制宜,全在如何权衡而已。本文讲述了绑定变量的使用方法,以及绑定变量的优缺点、使用场合。 一、绑定变量     提到绑定变量,就不得不了解硬解析与软解析。...二、绑定变量的使用     1、在SQLPlus中使用绑定变量 SQL> variable eno number; -->使用variable定义变量.../sql代码中,Oracle实现自动变量自动绑定,执行了30次的insert操作,但oracle认为每次执行的语句都是一样的 /*****************************...SQL中是使用绑定变量     -->动态SQL中不能自动使用绑定变量,需要手动设定绑定变量...缺点:         绑定变量被使用时,查询优化器会忽略其具体值,因此其预估的准确性远不如使用字面量值真实,尤其是在表存在数据倾斜(表上的数         据非均匀分布)的列上会提供错误的执行计划

    1.4K20

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

    最近在看《基于Oracle的SQL优化一书》,并做了笔记,作者的个人博客: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时,在Library Cache中找到了匹配的Parent Cursor和Child Cursor,并将存储在Child Cursor中的解析树和执行计划直接拿过来重用...方法就是用绑定变量的方法 二、绑定变量典型用法 2.1、在SQL中绑定变量 绑定变量的典型用法就是用 :variable_name的形式,variable_name是自定义的变量名称,variabl_name...execute immediate [sql语句] using [变量] 2.3、PL/SQL批量绑定变量 例子来自《基于Oracle的SQL优化》一书,要实现的的是批量绑定变量,fetch关键字,

    71120

    Oracle-Soft ParseHard ParseSoft Soft Parse解读

    概述 在Oracle中存在两种类型的SQL语句: 一类为 DDL语句(数据定义语言)CREATE,DROP,ALTER,他们是从来不会共享使用的,也就是每次执行都需要进行硬解析。...在执行软软解析之前,首先要进行软解析,MOS上说执行3次的SQL语句会把游标缓存到PGA,这个游标一直开着,当再有相同的SQL执行时,则跳过解析的所有过程直接去取执行计划。...当进程申请到闩后,则这些闩用于保护共享内存的数在同一时刻不会被两个以上的进程修改。 在硬解析时,需要申请闩的使用,而闩的数量在有限的情况下需要等待。...emp where empno=7788 --未使用绑定变量   select * from emp where empono=:eno --:eno即为绑定变量   在第二个查询中,变量值在查询执行时被提供...每一条都是一个硬解析,也耗时了3.7S , 使用绑定变量耗时0.4S….. 在未使用绑定变量的情形下,不论是解析次数,闩使用的数量,队列,分配的内存,库缓存,行缓存远远高于绑定变量的情况。

    2.3K20

    【DB笔试面试465】如何使用批量动态SQL(FORALL及BULK子句的使用)?

    题目部分 如何使用批量动态SQL(FORALL及BULK子句的使用)?...答案部分 批量动态SQL即在动态SQL中使用BULK子句,或使用游标变量时在FETCH中使用BULK,或在FORALL子句中使用BULK子句来实现。...结合BULK子句处理多行查询 在下面示例中,与前一个示例相同,只不过其动态SQL由查询语句组成,且返回多个结果集,同样使用了BULK COLLECT INTO来传递结果。...,游标变量以及复合类型,复合变量,接下来从动态SQL中OPEN游标,然后使用FETCH将结果存放到复合变量中。...下面的示例中,首先声明了两个复合类型以及复合变量,接下来为复合变量ENAME_TABLE赋值,以形成动态SQL语句。紧接着使用FORALL子句结合EXECUTE IMMEDIATE 来提取结果集。

    1.9K30

    【DB笔试面试464】动态SQL是什么?

    答案部分 在PL/SQL开发过程中,使用SQL或PL/SQL可以实现大部分的需求,但是,在某些特殊的情况下,在PL/SQL中使用标准的SQL语句或DML语句不能实现自己的需求,例如需要动态建表或执行某个不确定的操作的时候...因此,在Oracle数据库开发PL/SQL块中,可以把SQL分为静态SQL和动态SQL。所谓静态SQL指的是在PL/SQL块中使用的SQL语句在编译时是明确的,执行的是确定对象。...动态SQL是指在PL/SQL块编译时SQL语句是不确定的,如根据用户输入的参数的不同而执行不同的操作。编译程序对动态语句部分不进行处理,只是在程序运行时动态地创建语句、对语句进行语法分析并执行该语句。...动态SQL允许在SQL客户模块或嵌入式宿主程序的执行过程中执行动态生成的SQL语句,动态SQL语句在程序编译时尚未确定。...其中,有些部分需要在程序的执行过程中临时生成的SQL语句,SQL标准引入动态SQL的原因是由于静态SQL不能提供足够的编程灵活性。 动态SQL是使用EXECUTE IMMEDIATE语句来实现的。

    1.4K20

    Oracle PLSQL语句基础学习笔记(上)

    ,结构和组件、以及如何设计并执行一个PL/SQL程序。  ...当PL/SQL程序块在PL/SQL引擎处理时,ORACLE服务器中的SQL语句执行器处理pl/sql程序块中的SQL语句。...与其他语言相同,变量在使用之前必须声明,PL/SQL提供了独立的专门用于处理异常的部分。...执行一个PL/SQL块 SQL*PLUS中匿名的PL/SQL块的执行是在PL/SQL块后输入“/”来执行,如下面的例子所示: declare  v_comm_percent constant number...嵌套要注意的是变量,定义在最外部程序块中的变量可以在所有子块中使用,如果在子块中定义了与外部程序块变量相同的变量名,在执行子块时将使用子块中定义的变量。子块中定义的变量不能被父块引用。

    2.8K10
    领券