Oracle数据库中的变量

来源:https://blog.csdn.net/wahaa591/article/details/46772769

1、define(即host变量)

define variable_name = value

显示指定的DEFINE变量值和类型

//使用define def_name命令显示指定DEFINE变量的值和类型(DEFINE变量类型都为char)
SQL> define num;
DEFINE num = "1" (CHAR)

2、Variable(即绑定变量)

绑定变量主要是在sql中使用,达到sql解析一次,执行多次,从而提高效率的目的。绑定变量和host变量一样,也有定义的,也有临时性的。(临时性的在动态sql或动态plsql中通过占位符和using使用),其他的如sql会自动使用绑定变量的情况,此处不专门讨论。定义的绑定变量也是在当前session中有效。 绑定变量以下特点:

绑定变量在sql和plsql中直接引用必须加前缀 :。如要引用绑定变量a,则是 :a;

在真正运行的PLSQL程序中,比如自动运行,有自己的一套机制;

初始化和应用绑定变量,初始化定义的绑定变量,可以使用过程和函数,其中过程可以内部给绑定变量赋值、也可以参数是绑定变量,参数模式为out返回。使用函数和过程差不多,还可以使用call

函数来赋值。

sqlplus中可以使用大于等于3个字符表示一个命令,这里我们用var,var命令是声明一个绑定变量,只能给予名称和类型,定义的时候不能赋值,赋值可以在plsql中或者采用函数赋值(而host变量定义的时候必须赋值)。

(1).语法:

var var_name type

(2).声明绑定变量

//使用var声明两number类型的变量num1、num2

SQL> var num1 number;

SQL> var num2 number;

(3).显示指定绑定变量

//var num1命令显示指定绑定变量名称、数据类型

SQL> var num1

variable num1

datatype NUMBER

SQL>

还有一类SQLPLUS中的变量叫substitution variables,直接翻译过来是替代变量。一个使用替代变量的例子(来源:https://docs.oracle.com/cd/F49540_01/DOC/server.815/a66736/ch33.htm):

SQL> CLEAR BUFFER
SQL> INPUT
1 SELECT &GROUP_COL,
2 MAX(&NUMBER_COL) MAXIMUM
3 FROM &TABLE
4 GROUP BY &GROUP_COL
5
SQL> SAVE STATS
Created file STATS

Now run the command file STATS and respond as shown below to the prompts for values:

SQL>  @STATS
Enter value for group_col: JOB
old 1: SELECT &GROUP_COL,
new 1: SELECT JOB,
Enter value for number_col: SAL
old 2: MAX(&NUMBER_COL) MAXIMUM
new 2: MAX(SAL) MAXIMUM
Enter value for table: EMP
old 3: FROM &TABLE
new 3: FROM EMP
Enter value for group_col: JOB
old 4: GROUP BY &GROUP_COL
new 4: GROUP BY JOB

这类我之前在笔记中也写过:https://www.cnblogs.com/jiading/p/11578484.html。但是这类还有更多的文章可做,这也是我看了Oracle的官方文档才知道的。

如果上面的例子中,我们不仅要求最大值,还要求最小值、平均值,那么SQL脚本写出来应该是这样的:

select &Group_col,
max(&number_col1)maximun,min(&number_col1)minimum,avg(&number_col1)average
from &table
group by &group_col

这里我试的时候给number_col改了个名,原因后面见。

那么实际输入的时候是:

Enter value for group_col: JOB
old 1: select &Group_col,
new 1: select JOB,
Enter value for number_col1: SAL
Enter value for number_col1: SAL
Enter value for number_col1: SAL
old 2: max(&number_col1)maximun,min(&number_col1)minimum,avg(&number_col1)average
new 2: max(SAL)maximun,min(SAL)minimum,avg(SAL)average
Enter value for table: EMP
old 3: from &table
new 3: from EMP
Enter value for group_col: JOB
old 4: group by &group_col
new 4: group by JOB

可以看到,number_col1输入了三次。

为了简化操作,SQLPLUS提供了另外一种方式,如果将声明中的&变成&&,它就变成了一个变量(鉴于官方文档也没有给它起名字,我这里也就不起了吧):

select &Group_col,
max(&&number_col1)maximun,min(&&number_col1)minimum,avg(&&number_col1)average
from &table
group by &group_col

之后输入变成了这样:

Enter value for group_col: JOB
old 1: select &Group_col,
new 1: select JOB,
Enter value for number_col1: SAL
old 2: max(&&number_col1)maximun,min(&&number_col1)minimum,avg(&&number_col1)average
new 2: max(SAL)maximun,min(SAL)minimum,avg(SAL)average
Enter value for table: EMP
old 3: from &table
new 3: from EMP
Enter value for group_col: JOB
old 4: group by &group_col
new 4: group by JOB

可以看到,number_col1只需要输入一次了。

这里声明的变量在当前回话一直有效,再次运行STATS就会发现,&&number_col1不需要输入,而是自动填充了。这就是为什么我上面举例子为什么要改名的原因。

消除这一个变量声明的方法也很简单,退出现在的SQLPLUS进程再进入就没有了。

Oracle数据库中的变量的更多相关文章

  1. 向Oracle数据库中插入数据出错:ORA-01036 无效的变量名或数据

    向Oracle数据库中插入数据出错: 经过排查,因为Update数据时没有出错,所以OracleHelper没有问题: 看异常信息提示:无效的变量和数据,应该是SQL语句的问题,调试时所传的实例Use ...

  2. Oracle数据库中插入日期型数据(to_date的用法)(转载)

    往Oracle数据库中插入日期型数据(to_date的用法) INSERT  INTO  FLOOR  VALUES  ( to_date ( '2007-12-20 18:31:34' , 'YYY ...

  3. Oracle数据库中序列(SEQUENCE)的用法详解

    Oracle数据库中序列(SEQUENCE)的用法详解   在Oracle数据库中,序列的用途是生成表的主键值,可以在插入语句中引用,也可以通过查询检查当前值,或使序列增至下一个值.本文我们主要介绍了 ...

  4. 详解大数据采集引擎之Sqoop&采集oracle数据库中的数据

    一.Sqoop的简介: Sqoop是一个数据采集引擎/数据交换引擎,采集关系型数据库(RDBMS)中的数据,主要用于在RDBMS与HDFS/Hive/HBase之间进行数据传递,可以通过sqoop i ...

  5. Oracle 数据库的绑定变量特性及应用

    Oracle 数据库的绑定变量特性及应用[-----]转载自https://www.cnblogs.com/rootq/(原地址) 关键词: 绑定变量(binding variable),共享池(sh ...

  6. oracle 数据库中,应用程序里的连接探測语句的正确使用

    oracle 数据库中,应用程序里的连接探測语句的正确使用 本文为原创文章.转载请注明出处:http://blog.csdn.net/msdnchina/article/details/3851376 ...

  7. 查看Oracle数据库中的执行计划

    1.set autotrace traceonly命令 2.explain plan for命令 1)explain plan for select * from dual; 2)select * f ...

  8. 将Oracle数据库中的数据写入Excel

    将Oracle数据库中的数据写入Excel 1.准备工作 Oracle数据库"TBYZB_FIELD_PRESSURE"表中数据如图: Excel模板(201512.xls): 2 ...

  9. --关于null在oracle数据库中是否参与计算,进行验证,

    --关于null在oracle数据库中是否参与计算,进行验证,with td as (select null id,1 name from dual ),td1 as ( select null id ...

随机推荐

  1. koa 项目打包(使用webpack打包koa2 框架app)

    关键问题 一:所有node_modules里的模块都不进行打包 webpack的核心功能是将引用的各个模块打到一个文件里,并会将各种规范的模块进行统一的模块化处理(webpack规范). 然而node ...

  2. matplotlib:plt.rcParams设置画图的分辨率,大小等信息

    主要作用是设置画的图的分辨率,大小等信息 plt.rcParams['figure.figsize'] = (8.0, 4.0) # 设置figure_size尺寸 plt.rcParams['ima ...

  3. React Native 日常报错

    在学习React.js 或 React Native 过程中,有时看着别人的框架或代码,但总是会出现错误,因为React或之中用到的一些包经常更新,有些代码或教程就显得过旧了. 一.日常报错 'con ...

  4. 用key管理可复用元素

    先看看不用key管理可复用元素的代码.Vue 会尽可能高效地渲染元素,通常会复用已有元素而不是从头开始渲染.这么做,除了使 Vue 变得非常快之外,还有一些有用的好处,那就是在切换input时不会清楚 ...

  5. python3.6 列表推导式学习

    a=[i for i in range(1,10) if i%2==0]print(a)c=[(x,y) for x in range(5) if x%2==0 for y in range(5) i ...

  6. 在Android初次的前期学习中的二个小例子(2)

    Hello13:SQLite数据库 一.简述SQLite的概念和主要特性 SQLite是一个轻量级的关系型数据库,运算速度快,占用资源少,使用非常方便,支持SQL语法标准和数据库事务原则. 相对于Sh ...

  7. Spring Boot_打造企业级微信点餐系统_汇总贴

    2019更新版 Spring Boot双版本(1.5/2.1) 打造企业级微信点餐系统 H:\BaiDu\微服务0830\2019微服务时代Spring Boot双版本(1.5-2.1)  打造企业级 ...

  8. python 实例方法、类方法和静态方法

    #!/usr/bin/env python3.6 #-*- coding:utf-8 -*- # class Person(object): city = 'Beijing' def __init__ ...

  9. Jenkins - Tips

    01 - RPM包安装方式 默认路径 配置文件:/etc/sysconfig/jenkins 日志文件:/var/log/jenkins/jenkins.log 执行文件:/usr/lib/jenki ...

  10. 转:使用ActiveX插件时object显示问题,div被object标签遮挡的解决方案

    起因设计要求视频控制面板显示在视频界面上,如下图红框内所示.但是因为object不在文档流之中,所以不论别的元素设置z-index多高,都只会被object元素遮住而无法看到.object元素代码如下 ...