设为首页 收藏本站
查看: 908|回复: 0

[经验分享] oracle default 字段默认值无效

[复制链接]

尚未签到

发表于 2016-7-23 07:46:52 | 显示全部楼层 |阅读模式
几天前有人问我设置了字段的默认值为什么无效呢?查找了一些资料,做了一个总结:
  


Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.CodeHighlighter.com/

-->create table TEST
(
ID VARCHAR2(64),
A  VARCHAR2(3) default '0',
NAME VARCHAR2(100)
);
SQL> insert into test(a,name) values(null,'test');
1 row inserted
SQL> select * from test;
A   NAME
--- --------------------------------------------------------------------------------
    test


在上面的例子中,虽然A列设置了默认值为0,但插入空仍然无效。
其实对于默认值,Oracle支持两种方式:
? Default关键字
? 不指定列
先看第一种方式,



Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.CodeHighlighter.com/

-->SQL> insert into test(a,name) values(default,'test');
1 row inserted
SQL> select * from test;
A NAME
--- --------------------------------------------------------------------------------
0 test


列A终于有了默认值0。
再看第二种方式,



Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.CodeHighlighter.com/

-->SQL> insert into test2(name) values('test');
1 row inserted

SQL> select * from test2;
A NAME
--- --------------------------------------------------------------------------------
0 test



列A也被添加的默认值。
综上所述,Oracle的默认值处理要当心,如果应用中使用的是ORM工具,则必须要考虑对于字段为Null的处理,必要时在ORM工具中将Null转换为default或插入时去掉值为Null的字段。
可以将下面的系统属性作为默认值:
? SYSDATE:系统时间
? SYS_CONTEXT:系统上下文
? USER:当前数据库用户
? USERENV:用户环境变量,可以获取一些IP地址、协议、终端的信息
需要注意,默认值不能使用LEVEL、PRIOR、ROWNUM,会报ORA-00976错误。
应用中使用默认值的常见场景是主键或自增列。正如我们所知,Oracle并未提供自增类型,这就需要我们结合默认值进行二次开发,通过默认值实现系统应用的透明。这里结合笔者的经验,提供两种方案:
? 触发器+序列
因为Oracle不支持在default中使用序列,因此我们只能使用触发器来实现。



Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.CodeHighlighter.com/

-->create table TEST
(
ID VARCHAR2(64),
A VARCHAR2(3) default '0',
NAME VARCHAR2(100)
);
create sequence seq_test;
create or replace trigger tri_test
before insert on test for each row
begin
if :new.id is null then
select seq_test.nextval into :new.id from dual;
end if;
end;
/


这种方式适用于对于ID不要求连续性的场景。
? Sys_guid()。这个函数返回32位长的数据库全局唯一标识。我们可以使用这个函数作为默认值。



Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.CodeHighlighter.com/

-->alter table TEST modify ID default sys_guid()
SQL> insert into test2(name) values('张三');
1 row inserted
SQL> select * from test2;
ID A NAME
---------------------------------------------------------------- --- --------------------------------------------------------------------------------
7CDB1AF556F6474FABA74FA7A60F0822 0 张三

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

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-248028-1-1.html 上篇帖子: 查询oracle表空间使用情况 下篇帖子: Oracle字符串如何连接单引号
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表