Oracle字段的默认值无效的原因Oracle认证考试

文章作者 100test 发表时间 2009:07:25 11:16:38
来源 100Test.Com百考试题网


"tbbnc">   几天前有人问我设置了字段的默认值为什么无效呢?查找了一些资料,做了一个总结:
  createtableTEST
  (
  IDVARCHAR2(64),
  AVARCHAR2(3)default0,
  NAMEVARCHAR2(100)
  ).
  SQL>.insertintotest(a,name)values(null,test).
  1rowinserted
  SQL>.0select*fromtest.
  ANAME
  test
  在上面的例子中,虽然A列设置了默认值为0,但插入空仍然无效。
  其实对于默认值,Oracle支持两种方式:
  Default关键字
  不指定列
  先看第一种方式,
  SQL>.insertintotest(a,name)values(default,test).
  1rowinserted
  SQL>.0select*fromtest.
  ANAME
  0test
  列A终于有了默认值0。
  再看第二种方式,
  SQL>.insertintotest2(name)values(test).
  1rowinserted
  SQL>.0select*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)default0,
  NAMEVARCHAR2(100)
  ).
  createsequenceseq_test.
  createorreplacetriggertri_test
  beforeinsertontestforeachrow
  begin
  if:new.idisnullthen
  0selectseq_test.nextvalinto:new.idfromdual.
  endif.
  end.
  /
  这种方式适用于对于ID不要求连续性的场景。
  Sys_guid()。这个函数返回32位长的数据库全局唯一标识。我们可以使用这个函数作为默认值。
  altertableTESTmodifyIDdefaultsys_guid()
  SQL>.insertintotest2(name)values(张三).
  1rowinserted
  SQL>.0select*fromtest2.
  IDANAME
  7CDB1AF556F6474FABA74FA7A60F08220张三
  这种方式适用于ID不要求有含义,以及并发性较高的场景。

相关文章


讲解Oracle数据库LogMiner工具的使用方法Oracle认证考试
Oracle中存储过程和函数的区别Oracle认证考试
对比Caché和Oracle在数据库的应用Oracle认证考试
软件测试的自动化测试开发小案例Oracle认证考试
Oracle字段的默认值无效的原因Oracle认证考试
Oracle外部表的创建Oracle认证考试
Oracle中生成GUID类型Oracle认证考试
C 连接Oracle提示找不到某个库Oracle认证考试
Oracle10g物理备库也可置于read_write状态Oracle认证考试
澳大利亚华人论坛
考好网
日本华人论坛
华人移民留学论坛
英国华人论坛