sql - 如何声明变量并在同一个 Oracle SQL 脚本中使用它?

标签 sql oracle variables declaration

我想编写可重用的代码,需要在开头声明一些变量并在脚本中重用它们,例如:

DEFINE stupidvar = 'stupidvarcontent';

SELECT stupiddata
FROM stupidtable
WHERE stupidcolumn = &stupidvar;

如何声明变量并在后面的语句中重用它,例如在使用 SQLDeveloper 时。

<小时/>

尝试

  • 使用 DECLARE 部分并在 BEGINEND; 中插入以下 SELECT 语句。使用 &stupidvar 访问变量。
  • 使用关键字DEFINE并访问变量。
  • 使用关键字VARIABLE并访问变量。

但是我在尝试期间遇到了各种错误(未绑定(bind)变量、语法错误、预期的SELECT INTO...)。

最佳答案

在 SQL*Plus 脚本中声明变量的方法有多种。

第一种是使用 VAR,声明绑定(bind)变量。为 VAR 赋值的机制是通过 EXEC 调用:

SQL> var name varchar2(20)
SQL> exec :name := 'SALES'

PL/SQL procedure successfully completed.

SQL> select * from dept
  2  where dname = :name
  3  /

    DEPTNO DNAME          LOC
---------- -------------- -------------
        30 SALES          CHICAGO

SQL>

当我们想要调用具有 OUT 参数或函数的存储过程时,VAR 特别有用。

或者我们可以使用替换变量。这些对于交互模式很有用:

SQL> accept p_dno prompt "Please enter Department number: " default 10
Please enter Department number: 20
SQL> select ename, sal
  2  from emp
  3  where deptno = &p_dno
  4  /
old   3: where deptno = &p_dno
new   3: where deptno = 20

ENAME             SAL
---------- ----------
CLARKE            800
ROBERTSON        2975
RIGBY            3000
KULASH           1100
GASPAROTTO       3000

SQL>

当我们编写一个调用其他脚本的脚本时,预先定义变量会很有用。此代码片段运行时不会提示我输入值:

SQL> def p_dno = 40
SQL> select ename, sal
  2  from emp
  3  where deptno = &p_dno
  4  /
old   3: where deptno = &p_dno
new   3: where deptno = 40

no rows selected

SQL>

最后是匿名 PL/SQL block 。正如您所看到的,我们仍然可以交互式地为声明的变量赋值:

SQL> set serveroutput on size unlimited
SQL> declare
  2      n pls_integer;
  3      l_sal number := 3500;
  4      l_dno number := &dno;
  5  begin
  6      select count(*)
  7      into n
  8      from emp
  9      where sal > l_sal
 10      and deptno = l_dno;
 11      dbms_output.put_line('top earners = '||to_char(n));
 12  end;
 13  /
Enter value for dno: 10
old   4:     l_dno number := &dno;
new   4:     l_dno number := 10;
top earners = 1

PL/SQL procedure successfully completed.

SQL>

关于sql - 如何声明变量并在同一个 Oracle SQL 脚本中使用它?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3564283/

相关文章:

MySQL 距离关系的传递闭包

sql - 如何根据字符串从sql server中删除重复项

sql - 在SSIS中将固定宽度的行拆分为多行

sql - Oracle SQL-如何检索列的前5个值

Python:复制列表

Javascript - 如何让一个组合字母和数字的变量调用另一个变量

java - 如何使用 JPA 和 Hibernate 防止 SQL 注入(inject)?

sql - 子查询的自连接

c# - 使用现有的 C# 模型类构建实体图 (.EDMX)

php - 比较变量 foreach