id自增这一性质采用序列自增:
create sequence test_id_seq
increment by 1
start with 1
minvalue 1
maxvalue 9999
cycle
nocache
这里设置了序列循环,到后期可能会出现id重复,建议设置最大值大点,由于本次研究的是设计id固定格式自增,所以在这不做研究。
将序列以0000格式显示方法:
to_char(test_id_seq.nextval,'0000')
固定格式看个人需求,在这里采用的是字符XK+日期(年月),下面是进行拼接(直接在插入语句进行拼接):
开始:
采用||字符进行拼接:
insert into test(id) values('XK'||to_char(sysdate,'YYYYMM')||to_char(test_id_seq.nextval,'0000'));
即:insert into 表名(id) values('字符'||to_char(sysdate,'格式')||to_char(序列名.nextval,'格式')));
得到的结果会发现值里面含有一个空格,这并不是我们想要的结果,于是进一步完善(去除空格)。
用trim()方法只是去除头和尾的空格,在这里不符合要求,所以采用了replace()方法,如下:
insert into test(id) values(replace(('XK'||to_char(sysdate,'YYYYMM')||to_char(test_id_seq.nextval,'0000

本文介绍了如何在Oracle中利用序列和日期结合创建具有固定格式(如XK2022040001)并自增的ID。通过`to_char`、`sequence`和`replace`函数实现字符串与序列值的拼接,以满足特定格式需求,并解决拼接后可能出现的空格问题。
最低0.47元/天 解锁文章
1247

被折叠的 条评论
为什么被折叠?



