千家信息网

oracle创建固定长度的自增ID

发表于:2025-01-20 作者:千家信息网编辑
千家信息网最后更新 2025年01月20日,ORACLE的编号和SQL SERVER的不同。SQL SERVER可以设置一个值为自增。ORACLE需要先建立一个SEQUENCE,然后用NEXTVAL。例如,若想生成这样的编码,0001,0002
千家信息网最后更新 2025年01月20日oracle创建固定长度的自增ID

ORACLE的编号和SQL SERVER的不同。SQL SERVER可以设置一个值为自增。
ORACLE需要先建立一个SEQUENCE,然后用NEXTVAL。

例如,若想生成这样的编码,0001,0002,0003.。。。。。

首先建立一个1-n的整数循环序列,

CREATE SEQUENCE DATE_SEQ START WITH 1 --起始值(默认为1可省略) INCREMENT BY 1 --可省略(默认为1可省略) MAXVALUE 9999 --最大值9999 CYCLE --循环 NOCACHE --不缓存(可避免产生值不连续的情况) ORDER --保证按次序产生值
示例:create sequence TEST_ID  minvalue 1  maxvalue 9999start with 1  increment by 1  nocache;

有了1-9999的循环序列,我们就可以
TO_CHAR(DATE_SEQ.NEXTVAL) 先将其转换为字符形式。
然后 LPAD(TO_CHAR(DATE_SEQ.NEXTVAL),4,'0') 对其进行4位加'0'补齐长度。例如2,补齐为0002。

然后加上插入的日期(只要年月)
TO_CHAR(SYSDATE,'YYYYMM')||LPAD(TO_CHAR(DATE_SEQ.NEXTVAL),4,'0') --这样可以实现日期+编码的格式。

原文地址:http://plat.delit.cn/thread-144-1-1.html

转载请注明出处:

撰写人:度量科技http://www.delit.cn

0