Oracle
 sql >> Datenbank >  >> RDS >> Oracle

Wie weist man der Variablen im Ausdruck für einen PL/SQL-Block einen Wert zu?

Zusätzlich zum xor-Trick in PL/SQL können Sie einfach ein SQL-Statement verwenden

DECLARE
  a number := 17;
  b number := 42;
BEGIN
  SELECT a, b
    INTO b, a
    FROM dual;
  dbms_output.put_line( 'a = ' || a );
  dbms_output.put_line( 'b = ' || b );
END;

die die beiden Variablen vertauscht, ohne eine temporäre Variable zu verwenden

SQL> ed
Wrote file afiedt.buf

  1  DECLARE
  2    a number := 17;
  3    b number := 42;
  4  BEGIN
  5    SELECT a, b
  6      INTO b, a
  7      FROM dual;
  8    dbms_output.put_line( 'a = ' || a );
  9    dbms_output.put_line( 'b = ' || b );
 10* END;
SQL> /
a = 42
b = 17

PL/SQL procedure successfully completed.