几天前有人问我设置了字段的默认值为什么无效,查找了一些资料,总结如下:
create table TEST ( IDVARCHAR2(64), AVARCHAR2(3)default'0', NAMEVARCHAR2(100) );
SQL>insert into test(a,name) values(null,'test');
1 row inserted
SQL>select * from test;
A NAME
先看第一种方式,
SQL>insert into test(a,name)values(default,'test');
1 row inserted
SQL>select * from test;
A NAME
0 test
SQL>insert into test2(name) values('test');
1 row inserted
SQL>select * from test2;
A NAME
0 test
可以将下面的系统属性作为默认值:
SYSDATE:系统时间
SYS_CONTEXT:系统上下文
USER:当前数据库用户
USERENV:用户环境变量,可以获取一些IP地址、协议、终端的信息
需要注意,默认值不能使用LEVEL、PRIOR、ROWNUM,会报ORA-00976错误。
应用中使用默认值的常见场景是主键或自增列。正如我们所知,Oracle并未提供自增类型,这就需要我们结合默认值进行二次开发,通过默认值实现系统应用的透明。这里结合笔者的经验,提供两种方案:
触发器+序列
因为Oracle不支持在default中使用序列,因此我们只能使用触发器来实现。
create table TEST ( IDVARCHAR2(64), AVARCHAR2(3)default'0', NAMEVARCHAR2(100) );
create sequence seq_test;
create orreplace trigger tri_test
before insert on test for eachrow
begin
if:new.idisnullthen
select seq_test.nextvalinto:new.idfromdual;
endif;
end;
/
这种方式适用于对于ID不要求连续性的场景。
Sys_guid()。这个函数返回32位长的数据库全局唯一标识。我们可以使用这个函数作为默认值。
alter table TESTmodifyIDdefaultsys_guid()
SQL>insert into test2(name) values('张三');
1 row inserted
SQL>select * from test2;
ID ANAME
7CDB1AF556F6474FABA74FA7A60F08220 张三
这种方式适用于ID不要求有含义,以及并发性较高的场景。
create table TEST ( IDVARCHAR2(64), AVARCHAR2(3)default'0', NAMEVARCHAR2(100) );
SQL>insert into test(a,name) values(null,'test');
1 row inserted
SQL>select * from test;
A NAME
test
先看第一种方式,
SQL>insert into test(a,name)values(default,'test');
1 row inserted
SQL>select * from test;
A NAME
0 test
列A终于有了默认值0。
SQL>insert into test2(name) values('test');
1 row inserted
SQL>select * from test2;
A NAME
0 test
列A也被添加的默认值。
可以将下面的系统属性作为默认值:
SYSDATE:系统时间
SYS_CONTEXT:系统上下文
USER:当前数据库用户
USERENV:用户环境变量,可以获取一些IP地址、协议、终端的信息
需要注意,默认值不能使用LEVEL、PRIOR、ROWNUM,会报ORA-00976错误。
应用中使用默认值的常见场景是主键或自增列。正如我们所知,Oracle并未提供自增类型,这就需要我们结合默认值进行二次开发,通过默认值实现系统应用的透明。这里结合笔者的经验,提供两种方案:
触发器+序列
因为Oracle不支持在default中使用序列,因此我们只能使用触发器来实现。
create table TEST ( IDVARCHAR2(64), AVARCHAR2(3)default'0', NAMEVARCHAR2(100) );
create sequence seq_test;
create orreplace trigger tri_test
before insert on test for eachrow
begin
if:new.idisnullthen
select seq_test.nextvalinto:new.idfromdual;
endif;
end;
/
这种方式适用于对于ID不要求连续性的场景。
Sys_guid()。这个函数返回32位长的数据库全局唯一标识。我们可以使用这个函数作为默认值。
alter table TESTmodifyIDdefaultsys_guid()
SQL>insert into test2(name) values('张三');
1 row inserted
SQL>select * from test2;
ID ANAME
7CDB1AF556F6474FABA74FA7A60F08220 张三
这种方式适用于ID不要求有含义,以及并发性较高的场景。