Saltar al contenido

¿Cómo declarar la variable y usarla en el mismo script Oracle SQL?

Después de de nuestra prolongada selección de información hemos podido solucionar este atolladero que tienen algunos lectores. Te compartimos la respuesta y esperamos que resulte de gran ayuda.

Solución:

Hay varias formas de declarar variables en scripts SQL*Plus.

La primera es usar VAR, para declarar una variable de vinculación. El mecanismo de asignación de valores a un VAR es con una llamada 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>

Un VAR es particularmente útil cuando queremos llamar a un procedimiento almacenado que tiene parámetros OUT o una función.

Alternativamente, podemos usar variables de sustitución. Estos son buenos para el modo interactivo:

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>

Cuando estamos escribiendo un script que llama a otros scripts, puede ser útil DEFINIR las variables por adelantado. Este fragmento se ejecuta sin pedirme que ingrese un valor:

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>

Finalmente, está el bloque PL/SQL anónimo. Como puede ver, todavía podemos asignar valores a las variables declaradas de forma interactiva:

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>

Intente usar comillas dobles si se trata de una variable char:

DEFINE stupidvar = "'stupidvarcontent'";

o

DEFINE stupidvar = 'stupidvarcontent';

SELECT stupiddata  
FROM stupidtable  
WHERE stupidcolumn = '&stupidvar'

actualización:

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/[email protected]
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

En PL/SQL v.10

La palabra clave declare se usa para declarar una variable.

DECLARE stupidvar varchar(20);

para asignar un valor, puede establecerlo cuando declara

DECLARE stupidvar varchar(20) := '12345678';

o para seleccionar algo en esa variable que usas INTO declaración, sin embargo, debe envolver la declaración en BEGIN y ENDtambién debe asegurarse de que solo se devuelva un valor único, y no olvide los puntos y comas.

por lo que la declaración completa saldría a continuación:

DECLARE stupidvar varchar(20);
BEGIN
    SELECT stupid into stupidvar FROM stupiddata CC 
    WHERE stupidid = 2;
END;

Su variable solo se puede usar dentro de BEGIN y END así que si quieres usar más de uno tendrás que hacer múltiples BEGIN END envoltorios

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;

Espero que esto te ahorre algo de tiempo.

Sección de Reseñas y Valoraciones

¡Haz clic para puntuar esta entrada!
(Votos: 0 Promedio: 0)



Utiliza Nuestro Buscador

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *