我有一个带有无参数构造函数的对象类型,但是当我将其指定为该类型的列的默认值时,我收到 ORA-00904:无效标识符错误。
Example:
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 封装范例,我希望相同类型的所有字段都具有相同的默认“默认值”(希望你知道我的意思:-)
我在这里遗漏了一些东西,还是这是正常的并且不可能使用这样的非默认构造函数?
看来这是不可能的。
一种解决方法是使用触发器:
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”声明与此调用匹配
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)