oracle 创建自定义的流水号
流水号的格式是年月日(6位)+流水号(3位),比如140425001,这个流水号前6位是每天的日期,后3为是从001开始的,自增长+1.求怎么实现及设置,这个流水号非主键...
流水号的格式是 年月日(6位)+流水号(3位) ,比如 140425001,
这个流水号前6位是每天的日期,后3为是从001开始的,自增长+1.
求怎么实现及设置,这个流水号非主键
比如我有张表table abc{
id ....,
taskid ...,
....
}
怎么设置 taskid 展开
这个流水号前6位是每天的日期,后3为是从001开始的,自增长+1.
求怎么实现及设置,这个流水号非主键
比如我有张表table abc{
id ....,
taskid ...,
....
}
怎么设置 taskid 展开
1个回答
展开全部
create sequence seq_abc_taskid maxvalue 999; --你确定流水号只要3位?
使用它的下一个值用: seq_abc_taskid.nextval
查询当前值用:seq_abc_taskid.currval
比如你现在要插入一行到abc,你可以
insert into abc values (1,seq_abc_taskid.nextval,....);
使用它的下一个值用: seq_abc_taskid.nextval
查询当前值用:seq_abc_taskid.currval
比如你现在要插入一行到abc,你可以
insert into abc values (1,seq_abc_taskid.nextval,....);
追问
我想要的是日期加上这个流水号,这要怎么处理?
就比如20140428002,前8位日期加上后3位流水号
追答
select to_char(sysdate,'yyyymmdd')||seq_abc_taskid.nextval from dual;
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询