Oracle给字段id设置固定格式并且有自增效果(例如:XK2018040001(字符+日期+序列值)),构思:拼接

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')),' ',''));

即:insert into 表名(id) values(replace(('字符'||to_char(sysdate,'格式')||to_char(序列名.nextval,'格式')),' ','');

注意后面的' '和'',前者为空格字符,后者没有空格。

如果不用||字符进行拼接,则可采用concat函数进行拼接,只不过要采用嵌套的方式:

insert into test(id) values(replace((concat(concat('XK',to_char(sysdate,'YYYYMM')),to_char(test_id_seq.nextval,'0000'))),' ','');


关键在于对拼接方式||和concat(),以及replace()方法的混合运用。




你可能感兴趣的:(Oracle)