Oracle
 sql >> Baza danych >  >> RDS >> Oracle

Jak używać stałej pakietu w instrukcji SQL SELECT?

Nie możesz.

Aby publiczna zmienna pakietu została użyta w wyrażeniu SQL, musisz napisać funkcję opakowującą, która pokaże wartość światu zewnętrznemu:

SQL> create package my_constants_pkg
  2  as
  3    max_number constant number(2) := 42;
  4  end my_constants_pkg;
  5  /

Package created.

SQL> with t as
  2  ( select 10 x from dual union all
  3    select 50 from dual
  4  )
  5  select x
  6    from t
  7   where x < my_constants_pkg.max_number
  8  /
 where x < my_constants_pkg.max_number
           *
ERROR at line 7:
ORA-06553: PLS-221: 'MAX_NUMBER' is not a procedure or is undefined

Utwórz funkcję opakowującą:

SQL> create or replace package my_constants_pkg
  2  as
  3    function max_number return number;
  4  end my_constants_pkg;
  5  /

Package created.

SQL> create package body my_constants_pkg
  2  as
  3    cn_max_number constant number(2) := 42
  4    ;
  5    function max_number return number
  6    is
  7    begin
  8      return cn_max_number;
  9    end max_number
 10    ;
 11  end my_constants_pkg;
 12  /

Package body created.

A teraz to działa:

SQL> with t as
  2  ( select 10 x from dual union all
  3    select 50 from dual
  4  )
  5  select x
  6    from t
  7   where x < my_constants_pkg.max_number()
  8  /

         X
----------
        10

1 row selected.


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Czy możliwe jest zakleszczenie podczas aktualizowania i usuwania różnych wierszy w tabeli?

  2. Zapytanie rekurencyjne w Oracle

  3. Konfiguracja heterogenicznej replikacji baz danych — SQL Server do Oracle

  4. Różnica między Oracle IN a Exists?

  5. Zrób skumulowaną sumę w widoku wyrocznia