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()方法,如下ÿ