首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何声明变量并在同一个Oracle SQL脚本中使用它?

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

Stack Overflow用户
提问于 2010-08-25 17:03:12
回答 11查看 826.2K关注 0票数 144

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

代码语言:javascript
运行
复制
DEFINE stupidvar = 'stupidvarcontent';

SELECT stupiddata
FROM stupidtable
WHERE stupidcolumn = &stupidvar;

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

尝试

BEGINEND;中使用DECLARE节并插入以下SELECT语句。使用关键字&stupidvar.

  • Use访问变量,并访问variable.

  • Using关键字VARIABLE,然后访问变量。

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

EN

回答 11

Stack Overflow用户

回答已采纳

发布于 2010-08-25 18:15:24

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

第一种方法是使用VAR声明绑定变量。为VAR分配值的机制是使用EXEC调用:

代码语言:javascript
运行
复制
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特别有用。

或者,我们可以使用替代变量。这些对于交互模式是很好的:

代码语言:javascript
运行
复制
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>

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

代码语言:javascript
运行
复制
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块。如您所见,我们仍然可以交互地为声明的变量赋值:

代码语言:javascript
运行
复制
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>
票数 153
EN

Stack Overflow用户

发布于 2010-08-25 17:12:02

如果是char变量,请尝试使用双引号:

代码语言:javascript
运行
复制
DEFINE stupidvar = "'stupidvarcontent'";

代码语言:javascript
运行
复制
DEFINE stupidvar = 'stupidvarcontent';

SELECT stupiddata  
FROM stupidtable  
WHERE stupidcolumn = '&stupidvar'

更新:

代码语言:javascript
运行
复制
SQL*Plus: Release 10.2.0.1.0 - Production on Wed Aug 25 17:13:26 2010

Copyright (c) 1982, 2005, Oracle.  All rights reserved.

SQL> conn od/od@etalon
Connected.
SQL> define var = "'FL-208'";
SQL> select code from product where code = &var;
old   1: select code from product where code = &var
new   1: select code from product where code = 'FL-208'

CODE
---------------
FL-208

SQL> define var = 'FL-208';
SQL> select code from product where code = &var;
old   1: select code from product where code = &var
new   1: select code from product where code = FL-208
select code from product where code = FL-208
                                      *
ERROR at line 1:
ORA-06553: PLS-221: 'FL' is not a procedure or is undefined
票数 31
EN

Stack Overflow用户

发布于 2014-10-03 21:04:57

在PL/SQL v.10中

关键字declare用于声明变量

代码语言:javascript
运行
复制
DECLARE stupidvar varchar(20);

要赋值,可以在声明时设置该值

代码语言:javascript
运行
复制
DECLARE stupidvar varchar(20) := '12345678';

或者,要选择某个变量中的内容,您可以使用INTO语句,但是您需要在BEGINEND中包装语句,还需要确保只返回单个值,并且不要忘记使用分号。

因此,完整的声明如下:

代码语言:javascript
运行
复制
DECLARE stupidvar varchar(20);
BEGIN
    SELECT stupid into stupidvar FROM stupiddata CC 
    WHERE stupidid = 2;
END;

您的变量只能在BEGINEND中使用,因此如果您想使用多个变量,则必须执行多个BEGIN END包装

代码语言:javascript
运行
复制
DECLARE stupidvar varchar(20);
BEGIN
    SELECT stupid into stupidvar FROM stupiddata CC 
    WHERE stupidid = 2;

    DECLARE evenmorestupidvar varchar(20);
    BEGIN
        SELECT evenmorestupid into evenmorestupidvar FROM evenmorestupiddata CCC 
        WHERE evenmorestupidid = 42;

        INSERT INTO newstupiddata (newstupidcolumn, newevenmorestupidstupidcolumn)
        SELECT stupidvar, evenmorestupidvar 
        FROM dual

    END;
END;

希望这能节省你的时间

票数 22
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3564283

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档