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

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

♣ 题目部分 在Oracle中,绑定变量是什么?绑定变量有什么优缺点? ♣ 答案部分 绑定变量这节的内容较多,下面给出这节涉及到的关系图: ?...当表的列上存在数据倾斜(表上的数据非均匀分布)时,Oracle可能会提供错误的执行计划,从而使得非高效的执行计划被使用。...增长的时间主要耗费在执行目标SQL时对每一个绑定变量都用其实际的值来替换(这个过程就是所谓的绑定变量值替换),目标SQL的SQL文本中的绑定变量的个数越多,这个替换过程所耗费的时间就越长,该SQL总的执行时间也就越长...在PL/SQL中通过批量绑定的方式使用绑定变量。 PL/SQL中的“批量绑定”是一种优化后的使用绑定变量的方式。...③ 在Java中使用绑定变量 在Java中也有绑定变量和批量绑定的用法,本书不再详解。

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

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

    Q 题目 在Oracle中,什么是绑定变量窥探?...l 如果不使用绑定变量窥探,那么对于那些可选择率可能会随着具体输入值的不同而不同的谓词条件使用默认的可选择率(例如5%) 绑定变量窥探(Bind Peeking)是在Oracle 9i中引入的,是否启用绑定变量窥探受隐含参数...“_OPTIM_PEEK_USER_BINDS”的控制,该参数的默认值是TRUE,表示在Oracle 9i及其后续的版本中,默认启用绑定变量窥探。...绑定变量窥探的优缺点如下所示: ① 优点:当绑定变量窥探被启用后,每当Oracle以硬解析的方式解析使用了绑定变量的目标SQL时,Oracle都会实际窥探(Peeking)一下对应绑定变量的具体输入值,...关于绑定变量窥探需要注意以下几点: (1)在Oracle llg中引入自适应游标共享后,绑定变量窥探这种不管后续传入的绑定变量的具体输入值是什么而一直沿用之前硬解析时所产生的解析树和执行计划的缺点才有所缓解

    91920

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

    ♣ 题目部分 在Oracle中,什么是绑定变量分级?...l 定义长度在2000字节以上被分在第四个等级,Oracle为此等级的文本型绑定变量分配的内存空间大小取决于对应文本型绑定变量所传入的实际绑定变量值的大小。...如果在PL/SQL代码中使用了文本型绑定变量,只要其SQL文本中文本型绑定变量的定义长度发生了变化,那么Oracle为这些绑定变量所分配的内存空间的大小也可能会随之发生变化,而一旦Oracle为这些绑定变量所分配的内存空间的大小发生了变化...原因是子游标中除了会存储目标SQL的解析树和执行计划之外,还会存储该SQL所使用的绑定变量的类型和长度,这意味着即使该SQL的SQL文本没有发生任何改变,只要其SQL文本中文本型绑定变量的定义长度发生了变化...通过上述示例可以看出:为了避免不必要的硬解析,在PL/SQL代码中处理带文本型绑定变量的目标SQL时,应该将这些文本型绑定变量的定义长度保持在同一个等级,当然,这里最好是定义成一个统一的长度,比如VARCHAR2

    72010

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

    ♣ 题目部分 在Oracle中,如何查找未使用绑定变量的SQL语句?...如果SQL已使用绑定变量或者CURSOR_SHARING,那么FORCE_MATCHING_SIGNATURE在对其进行标识时将给出同样的签名。...⊙ 【DB笔试面试585】在Oracle中,什么是常规游标共享?⊙ 【DB笔试面试584】在Oracle中,如何得到已执行的目标SQL中的绑定变量的值?...⊙ 【DB笔试面试583】在Oracle中,什么是绑定变量分级?⊙ 【DB笔试面试582】在Oracle中,什么是绑定变量窥探(下)?...⊙ 【DB笔试面试582】在Oracle中,什么是绑定变量窥探(上)?⊙ 【DB笔试面试581】在Oracle中,绑定变量是什么?绑定变量有什么优缺点?

    6.4K20

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

    ♣ 题目部分 在Oracle中,什么是绑定变量窥探(上)?...l 如果不使用绑定变量窥探,那么对于那些可选择率可能会随着具体输入值的不同而不同的谓词条件使用默认的可选择率(例如5%) 绑定变量窥探(Bind Peeking)是在Oracle 9i中引入的,是否启用绑定变量窥探受隐含参数...: ① 优点:当绑定变量窥探被启用后,每当Oracle以硬解析的方式解析使用了绑定变量的目标SQL时,Oracle都会实际窥探(Peeking)一下对应绑定变量的具体输入值,并以这些具体输入值为标准,来决定这些使用了绑定变量的目标...关于绑定变量窥探需要注意以下几点: (1)在Oracle llg中引入自适应游标共享后,绑定变量窥探这种不管后续传入的绑定变量的具体输入值是什么而一直沿用之前硬解析时所产生的解析树和执行计划的缺点才有所缓解...在第2次执行使用绑定变量的SQL时不再重复做“窥探”动作。

    1.5K20

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

    当把绑定变量窥探关闭后再次执行目标SQL时所对应的解析树和执行计划应该存储在CHILD_NUMBER为1的Child Cursor中。...Binds”部分的内容,这都说明此时Oracle确实己经禁用了绑定变量窥探。...使用DDL操作可以让Oracle再次执行目标SQL时使用硬解析,但这种方法的弊端在于其影响范围还是太广了,因为一旦对某个表执行了DDL操作,再次执行与这个表相关的所有SQL时就会全部使用硬解析。...这意味着当把绑定变量窥探关闭后,无论对绑定变量X和Y传入的值是多少,都不会影响Oracle对于目标SQL执行计划的选择。...如果不使用绑定变量窥探,那么对于那些可选择率可能会随着具体输入值的变化而变化的谓词条件而言,Oracle会使用默认的可选择率(5%)。

    1.1K30

    【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面对“数据倾斜列使用绑定变量”场景的解决方案

    1.背景知识介绍     我们知道,Oracle在传统的OLTP(在线事务处理)类系统中,强烈推荐使用绑定变量,这样可以有效的减少硬解析从而增加系统的并发处理能力。...甚至在有些老旧系统,由于在开始开发阶段缺乏认识没有使用到绑定变量,后期并发量增长且无法改造程序时,运维DBA还会不得已去设置cursor_sharing=force来强制使用系统的绑定变量(这是一个万不得已的方案...虽然使用绑定变量给OLTP系统带来了巨大的好处,但也同时带来一些棘手的问题,最典型的就是由于SQL文本中包含绑定变量,优化器无法知道绑定变量代表的具体值,只能使用默认的可选择率,这就可能导致由于无法准确判断值的可选择率而造成选择错误的执行计划...Oracle在9i时代就有了针对这个问题的解决方案,即绑定变量窥探(bind peeking)特性。...,还可在应用发出SQL前,先判断其传入的值,是否是非典型值,若不是的话,使用非绑定变量的SQL;若是典型值,则使用绑定变量的语句。

    1.8K20

    『Jenkins』在Jenkins中实现环境变量的使用

    构建环境变量 Jenkins还提供了一些与构建过程相关的环境变量,通常用于动态地获取构建信息。这些变量通常会在构建开始时被自动定义,可以在Jenkinsfile或构建脚本中使用。...在Jenkins中配置环境变量 Jenkins提供了多种方式来配置和使用环境变量,包括全局环境变量、任务级别环境变量以及在Jenkinsfile中使用环境变量。 1....在Jenkinsfile中,环境变量的使用可以让构建过程更加灵活和动态。 3.1 定义和使用环境变量 在Jenkinsfile中,可以使用environment块来定义环境变量。...在构建脚本中使用环境变量 除了在Jenkinsfile中使用环境变量,我们还可以在构建脚本中使用它们。例如,在执行Shell或Batch脚本时,环境变量可以传递给脚本进行动态控制。...敏感信息的保护 在构建和部署过程中,经常需要使用一些敏感信息,如API密钥、数据库密码等。通过在Jenkins中使用环境变量,可以避免将敏感信息硬编码到代码中,从而提高安全性。

    18910

    【DB笔试面试849】在Oracle中,在没有配置ORACLE_HOME环境变量的情况下,如何获取ORACLE_HOME目录?

    ♣ 问题 在Oracle中,在没有配置ORACLE_HOME环境变量的情况下,如何快速获取数据库软件的ORACLE_HOME目录?...♣ 答案 若配置了ORACLE_HOME环境变量,则可以通过“echo $ORACLE_HOME”来直接获取,如下所示: [oracle@edsir4p1-PROD2 ~]$ echo $ORACLE_HOME.../u01/app/oracle/product/11.2.0/dbhome_1 [oracle@edsir4p1-PROD2 ~]$ sqlplus -v SQL*Plus: Release 11.2.0.1.0...Production 若没有配置ORACLE_HOME环境变量,则可以通过“more /etc/oratab”来直接获取,如下所示: [oracle@edsir4p1-PROD2 ~]$ more..._1:N 若数据库已启动监听程序,则可以通过“ps -ef|grep tns”来直接获取,如下所示: [oracle@edsir4p1-PROD2 ~]$ ps -ef|grep tns oracle

    2K50

    Oracle Apex系统变量大全--Oracle Apex社区教程www.sqlu.cn

    初学Apex的时候,老是会受到一个这样的困扰,它到底有什么系统变量?我该如何好好的利用他们!...很明显: APP_ID ; 表示本应用的Application_id 在PL/SQL或者SQL Expresstion可以直接用:APP_ID引用 APP_ALIAS : 表示当前APP的应用别名,可以在应用编辑页面设置...;然后 用:APP_ALIAS 引用 APP_PAGE_ID: 表示本应用中,当前打开页面的ID,这非常有用,我们不用写死Page ID了 初次以外我们还有以下四种方法来引用这些变量 引用类型 语法 绑定变量...除了上面几个很常用的以外,APEX还提供了下面43个系统变量,请大家对对号入座,用起来非常顺手 [ 隐藏内容 APEX$ROW_NUM APEX$ROW_SELECTOR APEX$ROW_STATUS...Apex社区教程 www.sqlu.cn Oracle Apex社区,Oracle Apex教程,Oracle Apex学习,Oracle Apex开发,Oracle Apex入门 EBS教程,EBS

    98860

    在PHP中如何使用全局变量的方法详解

    有很多方法能够使这些数据成为全局数据,其中最常用的就是使用“global”关键字申明,稍后在文章中我们会具体的讲解到。...在开发的过程中,你可能会知道知道每一个全局变量,但大概一年之后,你可能会忘记其中至少一般的全局变量,这个时候你会为自己使用那么多全局变量而懊悔不已。 那么如果我们不使用全局变量,我们该使用什么呢?...请求封装器 虽然我们的注册器已经使“global”关键字完全多余了,在我们的代码中还是存在一种类型的全局变量:超级全局变量,比如变量$_POST,$_GET。...虽然这些变量都非常标准,而且在你使用中也不会出什么问题,但是在某些情况下,你可能同样需要使用注册器来封装它们。 一个简单的解决方法就是写一个类来提供获取这些变量的接口。...> 正如你看到的,现在我们不再依靠任何全局变量了,而且我们完全让这些函数远离了全局变量。 结论 在本文中,我们演示了如何从根本上移除代码中的全局变量,而相应的用合适的函数和变量来替代。

    7.3K100

    WPF 的 ElementName 在 ContextMenu 中无法绑定成功?试试使用 x:Reference!

    WPF 的 ElementName 在 ContextMenu 中无法绑定成功?试试使用 x:Reference!...,我们为一段文字中的一个部分绑定了主窗口的的一个属性,于是我们使用 ElementName 来指定绑定源为 WalterlvWindow。...▲ 使用普通的 ElementName 绑定 以下代码就无法正常工作了 保持以上代码不变,我们现在新增一个 ContextMenu,然后在 ContextMenu 中使用一模一样的绑定表达式: 使用 x:Reference 代替 ElementName 能够解决 以上绑定失败的原因,是 Grid.ContextMenu 属性中赋值的 ContextMenu 不在可视化树中,而 ContextMenu...类似的情况也发生在设置非可视化树或逻辑树的属性时,典型的比如在 Grid.Row 或 Grid.Column 属性上绑定时,ElementName 也是失效的。

    3.1K50
    领券