У меня есть тип объекта с конструктором без аргументов, но когда я указываю его в качестве значения по умолчанию для столбца этого типа, я получаю 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, я хочу, чтобы все поля одного типа имели одинаковые значения по умолчанию (надеюсь, вы знаете, чтоЯ имею в виду: -)
Я что-то здесь упустил, или это нормально, и невозможно использовать конструкторы не по умолчанию, как это?