Oracle: указание значения по умолчанию для столбца типа объекта - PullRequest
6 голосов
/ 29 марта 2012

У меня есть тип объекта с конструктором без аргументов, но когда я указываю его в качестве значения по умолчанию для столбца этого типа, я получаю ORA-00904: ошибка неверного идентификатора.

Пример:

CREATE OR REPLACE TYPE test_t AS OBJECT
(
  val      NUMBER(10),
  CONSTRUCTOR FUNCTION test_t return self as result
)

CREATE OR REPLACE TYPE BODY test_t AS 
  CONSTRUCTOR FUNCTION test_t RETURN SELF AS RESULT IS
  BEGIN
    val := 1;
    RETURN;
  END;
END;

CREATE TABLE test_table (
    test_attr test_t DEFAULT new test_t()
)

Error: ORA-00904: "INKA"."TEST_T"."TEST_T": invalid identifier

Если я заменю DEFAULT, например, test_t (1), это сработает, но это нарушает парадигму инкапсуляции OO, я хочу, чтобы все поля одного типа имели одинаковые значения по умолчанию (надеюсь, вы знаете, чтоЯ имею в виду: -)

Я что-то здесь упустил, или это нормально, и невозможно использовать конструкторы не по умолчанию, как это?

1 Ответ

1 голос
/ 29 марта 2012

Похоже, что это невозможно.

Одним из обходных путей может быть использование триггера:

CREATE OR REPLACE TRIGGER test_trigger
  BEFORE INSERT OR UPDATE
ON test_table
  FOR EACH ROW
WHEN ( new.test_attr IS NULL )
BEGIN
  :new.test_attr := NEW test_t();
END test_trigger;
/

Между прочим, он не полностью игнорирует конструкторы не по умолчанию,переопределение конструктора по умолчанию

CONSTRUCTOR FUNCTION test_t(in_val NUMBER)
RETURN SELF AS RESULT

приводит к исключению при попытке определить таблицу с помощью DEFAULT NEW test_t(1):

ORA-06553: PLS-307: слишком много объявлений 'TEST_T 'соответствует этому вызову

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...