我有一个无参数构造函数的对象类型,但是当我将它指定为该类型列的默认值时,我得到ORA-00904:无效标识符错误。Oracle:指定对象类型的默认值列
实施例:
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封装范例,我希望所有相同类型的字段具有相同的默认“默认值”(希望你知道我的意思:-)
我是否缺少在这里的东西,或者这是正常的,它是不可能使用这样的非默认构造函数?