资讯

精准传达 • 有效沟通

从品牌网站建设到网络营销策划,从策略到执行的一站式服务

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 9999
start 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


分享文章:oracle创建固定长度的自增ID
分享地址:http://cdkjz.cn/article/peeosc.html
多年建站经验

多一份参考,总有益处

联系快上网,免费获得专属《策划方案》及报价

咨询相关问题或预约面谈,可以通过以下方式与我们联系

业务热线:400-028-6601 / 大客户专线   成都:13518219792   座机:028-86922220