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 END
tambié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.