- Rongsen.Com.Cn 版权所有 2008-2010 京ICP备08007000号 京公海网安备11010802026356号 朝阳网安编号:110105199号
- 北京黑客防线网安工作室-黑客防线网安服务器维护基地为您提供专业的
服务器维护
,企业网站维护
,网站维护
服务 - (建议采用1024×768分辨率,以达到最佳视觉效果) Powered by 黑客防线网安 ©2009-2010 www.rongsen.com.cn
作者:黑客防线网安Oracle维护基地 来源:黑客防线网安Oracle维护基地 浏览次数:0 |
几天前有人问我设置了字段的默认值为什么无效呢?查找了一些资料,做了一个总结:
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不要求有含义,以及并发性较高的场景。
我要申请本站:N点 | 黑客防线官网 | |
专业服务器维护及网站维护手工安全搭建环境,网站安全加固服务。黑客防线网安服务器维护基地招商进行中!QQ:29769479 |