替换变量

SQL*Plus中的替换变量又叫替代变量,它一般用来临时存储相关数据;在SQL语句之间传递值。一般使用&或&&前缀来指定替换变量. 关于使用替换变量,一般是利用其创建通用的脚本或达到和用户交换目的。如下所示:

例如,我需要查看表的相关信息,如果不使用替换变量,每次查询我都要修改脚本。非常不便,如果使用替换变量,我们可以将下面脚本存放在tab.sql脚本中,每次运行时,只需要输入替换变量的值就可以了。

COL LOGGING FOR A7;

 

COL OWNER FOR A12;

 

COL TABLE_NAME FOR A30

 

COL TABLESPACE_NAME FOR A30

 

SELECT OWNER, TABLE_NAME, TABLESPACE_NAME, STATUS, COMPRESSION, 

       LOGGING, PARTITIONED, NUM_ROWS,

       TO_CHAR(LAST_ANALYZED,'YY-MM-DD HH24:MI:SS') LAST_ANALYZED

 

FROM DBA_TABLES 

 

    WHERE TABLE_NAME LIKE '&table_name_like%'

 

    ORDER BY TABLE_NAME;

 

epps> @tab.sql

Enter value for table_name_like: EMP

old   4:  WHERE  TABLE_NAME LIKE '&table_name_like%'

new   4:  WHERE  TABLE_NAME LIKE 'EMP%'

 

OWNER     TABLE_NAME       TABLESPACE_NAME      STATUS   COMPRESS LOGGING PAR   NUM_ROWS LAST_ANALYZED

------- --------------- ---------------------- -------- -------- ------- --- ---------- -----------------

SCOTT        EMP               USERS             VALID    DISABLED YES     NO          14 09-07-20 22:00:12

WIPOWNER     EMPLOYEE_MASTER   WIPOWNER_DATA     VALID    DISABLED YES     NO       12084 14-09-07 14:08:22

 

epps> @tab.sql

Enter value for table_name_like: DEPT

old   4:  WHERE  TABLE_NAME LIKE '&table_name_like%'

new   4:  WHERE  TABLE_NAME LIKE 'DEPT%'

 

OWNER     TABLE_NAME    TABLESPACE_NAME    STATUS   COMPRESS LOGGING PAR   NUM_ROWS LAST_ANALYZED

------- -------------- ------------------ -------- -------- ------- --- ---------- -----------------

SCOTT       DEPT                USERS       VALID    DISABLED YES     NO           4 09-07-20 22:00:12

 

epps> 

如果替换变量为数字类型,那么可以直接是&+变量名称,如下所示&DEPTNO,

SQL> SELECT deptno, dname, loc 

  2  FROM SCOTT.DEPT

  3  WHERE DEPTNO= &DEPTNO;

Enter value for deptno: 10

old   3: WHERE DEPTNO= &DEPTNO

new   3: WHERE DEPTNO= 10

 

    DEPTNO DNAME          LOC

---------- -------------- -------------

        10 ACCOUNTING     NEW YORK

如果是字符串类型或日期类型,最好使用单引号将其包裹起来,否则在输入变量值时则必须加上单引号,不那样做就会报错,如下所示。

SQL> SELECT deptno, dname, loc 

  2  FROM SCOTT.DEPT

  3  WHERE DNAME= &DNAME;

Enter value for dname: SALES

old   3: WHERE DNAME= &DNAME

new   3: WHERE DNAME= SALES

WHERE DNAME= SALES

             *

ERROR at line 3:

ORA-00904: "SALES": invalid identifier

 

SQL> SELECT deptno, dname, loc 

  2  FROM SCOTT.DEPT

  3  WHERE DNAME= &DNAME;

Enter value for dname: 'SALES'

old   3: WHERE DNAME= &DNAME

new   3: WHERE DNAME= 'SALES'

 

    DEPTNO DNAME          LOC

---------- -------------- -------------

        30 SALES          CHICAGO

关于替换变量中&与&&的区别,两者区别在于作用范围不一样,&引用的替换变量只在当前SQL有效,而&&引用的替换变量则在当前会话有效。下面以人们经常引用的例子来说明

SQL> SELECT 2+&NUM FROM DUAL;

Enter value for num: 2

old   1: SELECT 2+&NUM FROM DUAL

new   1: SELECT 2+2 FROM DUAL

 

       2+2

----------

         4

 

SQL> SELECT 3+&NUM FROM DUAL;

Enter value for num: 3

old   1: SELECT 3+&NUM FROM DUAL

new   1: SELECT 3+3 FROM DUAL

 

       3+3

----------

         6

 

SQL> SELECT 2+&&NUM FROM DUAL;

Enter value for num: 2

old   1: SELECT 2+&&NUM FROM DUAL

new   1: SELECT 2+2 FROM DUAL

 

       2+2

----------

         4

 

SQL> SELECT 3+&&NUM FROM DUAL;

old   1: SELECT 3+&&NUM FROM DUAL

new   1: SELECT 3+2 FROM DUAL

 

       3+2

----------

         5

 

小知识1:在存储过程或包体里面,经常有在字符串中使用&的情况,执行脚本时,经常会将这些字符串视为替换变量,要求输入值,这样烦不甚烦,其实只需要设置一下SQL*PLUS的环境变量即可避免这种情况。通常通过SET DEFINE OFF

小知识2:如果要显示SQL*Plus使用替换值替换后的脚本文件,可以使用SET VERIFY ON/OFF 命令

SQL> SET VERIFY OFF

SQL> SELECT 2+&NUM FROM DUAL;

 

       2+2

----------

         4

 

SQL> SET VERIFY ON

SQL> SELECT 2+&NUM FROM DUAL;

old   1: SELECT 2+&NUM FROM DUAL

new   1: SELECT 2+2 FROM DUAL

 

       2+2

----------

         4

 

 

用户定义变量

使用DEFINE定义了的变量(或许我们可以叫其定义常量,和C/C++中的DEFINE非常类似),可以使用&引用声明的变量。其作用范围或生命周期通常是整个会话。如果定义了变量后,需要清除变量,则可以使用UNDEFINE清除变量,使用DEFINE VARIABLE来查看变量

SQL> DEFINE NUM=2;            --定义变量

SQL> DEFINE NUM                    --查看变量

DEFINE NUM             = "2" (CHAR)

SQL> SELECT 2+&NUM FROM DUAL;      --引用变量

old   1: SELECT 2+&NUM FROM DUAL

new   1: SELECT 2+2 FROM DUAL

 

       2+2

----------

         4

 

SQL> UNDEFINE NUM;               --清除变量

SQL> SELECT 2+&NUM FROM DUAL;    --清除变量后,&NUM变成替换变量了。需要输入值

Enter value for num: 

 

小知识点:查看当前会话下,SQL*Plus下定义的变量

SQL> define

DEFINE _DATE = "11-SEP-14" (CHAR)

DEFINE _CONNECT_IDENTIFIER = "epps" (CHAR)

DEFINE _USER = "SYS" (CHAR)

DEFINE _PRIVILEGE = "AS SYSDBA" (CHAR)

DEFINE _SQLPLUS_RELEASE = "1002000400" (CHAR)

DEFINE _EDITOR = "ed" (CHAR)

DEFINE _O_VERSION = "Oracle Database 10g Release 10.2.0.4.0 - Production" (CHAR)

DEFINE _O_RELEASE = "1002000400" (CHAR)

 

 

VARIABLE变量和DEFINE变量不同的是其需要指定变量类型,类似编程语言中的强类型和弱类型变量。前者用于绑定变量,后者是用于&或&&进行变量替换

SQL> VAR NUM NUMBER;

SQL> EXEC :NUM :=10;

PL/SQL procedure successfully completed.

SQL> PRINT NUM;

NUM

----------

10

DECLARE定义变量则一般用于PL/SQL中。一般大家也用得比较多。在此不做说明。

参考资料:

http://www.doc88.com/p-783671200732.html

http://blog.itpub.net/9933980/viewspace-627702/

http://blog.csdn.net/haiross/article/details/15340489

SQL*Plus中替换变量与定义变量的更多相关文章

  1. SQL Server中的临时表和表变量

    SQL Server中的临时表和表变量 作者:DrillChina出处:blog2008-07-08 10:05 在SQL Server的性能调优中,有一个不可比拟的问题:那就是如何在一段需要长时间的 ...

  2. JavaScript中var和this定义变量的区别

    JavaScript中var和this定义变量的区别 在js中声明变量时可以使用var和this,但使用this的有很大一部分参考书是没有的,经过查阅相关资料总结如下: 用var和this声明变量,存 ...

  3. 『Python基础-3』变量、定义变量、变量类型、关键字Python基础-3』变量、定义变量、变量类型、关键字

    『Python基础-3』变量.定义变量.变量类型.关键字 目录: 1.Python变量.变量的命名 2.变量的类型(Python数据类型) 3.Python关键字 1. Python 变量.变量的命名 ...

  4. SQL Server中的临时表和表变量 Declare @Tablename Table

    在SQL Server的性能调优中,有一个不可比面的问题:那就是如何在一段需要长时间的代码或被频繁调用的代码中处理临时数据集?表变量和临时表是两种选择.记得在给一家国内首屈一指的海运公司作SQL Se ...

  5. sql server中的临时表、表变量和公用表表达式

    在编写T-SQL语句的时候,SQL Server提供了三种方法临时存储某些结果集,分别是临时表.表变量和公用表表达式. 临时表 临时表需要在临时数据库TempDB中通过I/O操作来创建表结构,一旦用户 ...

  6. SQL Server中可能为null的变量逻辑运算的时候要小心

    DECLARE @a int declare @b int IF(@a<>@b) print('@a<>@b') else print('@a=@b') ) print('b& ...

  7. MySQL存储过程中declare和set定义变量的区别

    在存储过程中常看到declare定义的变量和@set定义的变量.简单的来说,declare定义的类似是局部变量,@set定义的类似全局变量. 1.declare定义的变量类似java类中的局部变量,仅 ...

  8. mysql -- 存储过程中 declare 和 set 定义变量的区别

    mysql存储过程中,定义变量有两种方式:1.使用set或select直接赋值,变量名以 @ 开头.例如:set @var=1;可以在一个会话的任何地方声明,作用域是整个会话,称为会话变量. 2.以 ...

  9. js中let和var定义变量的区别

    let变量之前没见过,刚遇到,探探究竟. 以下转自:http://blog.csdn.net/nfer_zhuang/article/details/48781671 声明后未赋值,表现相同 (fun ...

随机推荐

  1. Yii2的深入学习--事件Event

    我们先来看下事件在 Yii2 中的使用,如下内容摘自 Yii2中文文档 事件可以将自定义代码“注入”到现有代码中的特定执行点.附加自定义代码到某个事件,当这个事件被触发时,这些代码就会自动执行.例如, ...

  2. iOS UIWebView 拦截点击事件(双击缩放)

    在平时的开发中,要使用到webview,但类似微信的webview在数据没有加载完成的时候 双击屏幕,webview不会缩放,其实实现这个功能很简单 代码是用swift写的 class YYSimpl ...

  3. angular使用总结

    一.是否有必要加入模块化框架 1.Reqruiejs seajs的主要作用 (1)模块化,让代码易于维护. angular本身就是mvc,模块化很清晰,所以这点用不到requirejs (2)可以按需 ...

  4. vue-lazy-render: 延迟渲染大组件,增强页面切换流畅度

    最近用element来做项目,在开发的过程中,突然发现页面的操作和切换在数据量大的时候相当卡,后来提了个issue,在furybean解答后才知道,我每个单元格都加了tooltip,会生成大量的节点, ...

  5. 《Head First 设计模式》之观察者模式

    作者:Grey 原文地址:http://www.cnblogs.com/greyzeng/p/5918205.html 模式名称 观察者模式(Observer Pattern) 需求 我们要通过Wea ...

  6. 【那些年关于MyEclipse的快捷键大全】

    MyEclipse 快捷键1(CTRL)-------------------------------------Ctrl+1 快速修复Ctrl+D: 删除当前行 Ctrl+Q  定位到最后编辑的地方 ...

  7. LaTeX

    毕业论文用LaTeX编辑,方便使用,专注于内容.无须分心于格式. 字符 - Char 希腊符号 加粗 \usepackage{amsmath} \boldsymbol{\sigma} \usepack ...

  8. 生成树形结构的json字符串代码(c#)供前端angular tree使用.

    框架是使用EF6.0.可以针对返回的值使用Newtonsoft.Json.dll(百度搜一下)来对返回的值序列化为json字符串,如果对以下值那就是使用JsonConvert.SerializeObj ...

  9. php实现设计模式之 职责链模式

    <?php /** * 职责链模式 * * 为解除请求的发送者和接收者之间的耦合,而使用多个对象都用机会处理这个请求,将这些对象连成一条链,并沿着这条链传递该请求,直到有一个对象处理它 * 抽象 ...

  10. Lind.DDD~实体属性变更追踪器的实现

    回到目录 看着这个标题很复杂,大叔把它拆开说一下,实体属性-变更-追踪器,把它拆成三部分大家看起来就容易懂一些了,实体属性:领域实体里有自己的属性,属性有getter,setter块,用来返回和设置属 ...