oracle sql列默认值,sql – Oracle:指定对象类型列的默认值

我有一个带有no-args构造函数的对象类型,但是当我将它指定为该类型列的默认值时,我得到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封装范式,我希望所有相同类型的字段都具有相同的默认“默认值”(希望你知道我的意思:-)

我在这里遗漏了什么,或者这是正常的,并且不可能使用像这样的非默认构造函数?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值