В Oracle, как проверить тип объекта, используемый из иерархии типов объектов? - PullRequest
0 голосов
/ 26 июня 2018

У меня есть иерархия типов в схеме Oracle:

CREATE OR REPLACE TYPE FV AS OBJECT (
   idno           NUMBER)
NOT FINAL;
/

CREATE TYPE FV_Integer UNDER FV (
   features INTEGER_ARRAY)
   NOT FINAL;
/


CREATE TYPE FV_Number UNDER FV (
   features NUMBER_ARRAY)
   NOT FINAL;
/

Я хочу создать функцию PLSQL, которая позволяет определить, какой тип иерархии является объектом: для фиктивной функции (obj1 FV, obj2 FV) ... как я могу проверить, какой тип объекта иерархии использует пользователь?

Например, я хочу напечатать имена типов объектов (функция предназначена для иллюстрации, она не настоящая).код pl / sql):

 dummy(obj1 FV, obj2 FV){
      if obj1%type = FV_INTEGER
          THEN print 'FV_INTEGER'
      endif
      if obj2%type = FV_NUMBER
          THEN print 'FV_NUMBER'
      endif
}

Ответы [ 2 ]

0 голосов
/ 26 июня 2018

Вы можете проверить тип объекта, используя sys.anydata:

create or replace function which_type
    ( p_fv fv )
    return varchar2
as
begin
    return sys.anydata.gettypename(sys.anydata.convertobject(p_fv));
end which_type;

Тест:

create or replace type number_array as table of number;
create or replace type integer_array as table of integer;

create or replace type fv as object (
   idno           number)
not final;
/

create type fv_integer under fv (
   features integer_array)
   not final;
/

create type fv_number under fv (
   features number_array)
   not final;
/

create table fv_test (my_fv fv);

insert into fv_test values (fv(1));
insert into fv_test values (fv_integer(1, integer_array(1)));
insert into fv_test values (fv_number(1, number_array(1)));

select which_type(my_fv) from fv_test;

WHICH_TYPE(MY_FV)
-------------------------
WILLIAM.FV
WILLIAM.FV_INTEGER
WILLIAM.FV_NUMBER

3 rows selected.
0 голосов
/ 26 июня 2018

Используйте user_types словарь для создания функции:

SQL> set serveroutput on;
SQL> create or replace function chk_typ_obj( i_type_name user_types.type_name%type )
  2  return pls_integer is
  3    o_val pls_integer;
  4  begin
  5    for c in
  6      (
  7      select decode(t.incomplete,'NO',1,0) icomp
  8        from user_types t
  9       where t.type_name = i_type_name
 10      )
 11      loop
 12        o_val := c.icomp;
 13      end loop;
 14  
 15        return o_val;
 16  end;
 17  /

Function created

SQL> var o_val number;
SQL> exec :o_val := chk_typ_obj('FV');

PL/SQL procedure successfully completed
o_val
---------
1

SQL> exec :o_val := chk_typ_obj('FV_NUMBER');

PL/SQL procedure successfully completed
o_val
---------
0

Объявление является неполным, если в нем пропущено AS OBJECT.

Итак, если chk_typ_obj

  • возвращает 1, то он имеет ТИП ОБЪЕКТА

  • возвращает 0, тогда он не имеет значения TYPE OBJECT

  • возвращается ноль, тогда нет такого типа, вызываемого этим именем

...