虫虫技术在线--技术决定出路

当前位置: 首页 > 数据库 > Oracle >

Oracle字段的默认值无效的原因

时间:2010-05-07 00:43来源:虫虫技术在线收集整理 作者:虫虫编辑 点击:
几天前有人问我设置了字段的默认值为什么无效呢?查找了一些资料,做了一个总结: createtableTEST ( IDVARCHAR2(64), AVARCHAR2(3)default'0', NAMEVARCHAR2(100) ); SQLinsertintotest(a,name)values(null,'test'); 1r

  几天前有人问我设置了字段的默认值为什么无效呢?查找了一些资料,做了一个总结:


  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位长的数据库全局唯一标识。我们可以使用这个函数作为默认值。


  altertableTESTmodifyIDdefaultsys_guid()
  SQL>insertintotest2(name)values('张三');
  1rowinserted
  SQL>select*fromtest2;
  IDANAME
  ---------------------------------------------------------------------------------------------------------------------------------------------------
  7CDB1AF556F6474FABA74FA7A60F08220张三

  这种方式适用于ID不要求有含义,以及并发性较高的场景。

(责任编辑:admin)
顶一下
(0)
0%
踩一下
(0)
0%
------分隔线----------------------------
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价:
表情:
用户名: 验证码:点击我更换图片
栏目列表
推荐内容