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

本文介绍了如何在Oracle中利用序列和日期结合创建具有固定格式(如XK2022040001)并自增的ID。通过`to_char`、`sequence`和`replace`函数实现字符串与序列值的拼接,以满足特定格式需求,并解决拼接后可能出现的空格问题。
摘要由CSDN通过智能技术生成

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值