oracle默认guid没用,Oracle字段的默认值无效的原因有哪些?

createtableTEST

(

IDVARCHAR2(64),

AVARCHAR2

(3)default'0',

NAMEVARCHAR2(100)

);

SQL>insertintotest(a,name)values(null,'test');

1rowinserted

SQL>select*fromtest;

ANAME

test

在上面的例子中,虽然A列设置了默认值为0,但插入空仍然无效。

其实对于默认值,Oracle支持两种方式:

Default关键字

不指定列

先看第一种方式,

SQL>insertintotest(a,name)values(default,'test');

1rowinserted

SQL>select*fromtest;

ANAME

0test

列A终于有了默认值0。

再看第二种方式,

SQL>insertintotest2(name)values('test');

1rowinserted

SQL>select*fromtest2;

ANAME

0test

列A也被添加的默认值。

综上所述,Oracle的默认值处理要当心,如果应用中使用的是ORM工具,则必须要考虑对于字段为Null的处理,必要时在ORM工具中将Null转换为default或插入时去掉值为Null的字段。

可以将下面的系统属性作为默认值:

SYSDATE:系统时间

SYS_CONTEXT:系统上下文

USER:当前数据库用户

USERENV:用户环境变量,可以获取一些IP地址、协议、终端的信息

需要注意,默认值不能使用LEVEL、PRIOR、ROWNUM,会报ORA-00976错误。

应用中使用默认值的常见场景是主键或自增列。正如我们所知,Oracle并未提供自增类型,这就需要我们结合默认值进行二次开发,通过默认值实现系统应用的透明。这里结合笔者的经验,提供两种方案:

触发器+序列

因为Oracle不支持在default中使用序列,因此我们只能使用触发器来实现。

createtableTEST

(

IDVARCHAR2(64),

AVARCHAR2

(3)default'0',

NAMEVARCHAR2(100)

);

createsequenceseq_test;

createorreplacetriggertri_test

beforeinsertontestforeachrow

begin

if:new。

idisnullthen

selectseq_test。nextvalinto:new。idfromdual;

endif;

end;

/

这种方式适用于对于ID不要求连续性的场景。

Sys_guid()。这个函数返回32位长的数据库全局唯一标识。

我们可以使用这个函数作为默认值。

全部

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值