oracle创建固定长度的自增ID
2015-10-19 15:10
393 查看
ORACLE的编号和SQL SERVER的不同。SQL SERVER可以设置一个值为自增。
ORACLE需要先建立一个SEQUENCE,然后用NEXTVAL。
例如,若想生成这样的编码,0001,0002,0003.。。。。。
首先建立一个1-n的整数循环序列,
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需要先建立一个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
相关文章推荐
- 谈下oracle11gR2 dataguard部署测试
- 浅析oracle备份脚本代码
- oracle 第10章 控制文件
- oracle中substr函数的用法
- oracle record is locked by another user
- ORACLE用户自动被锁解决方法
- ibatis动态多条件查询及模糊查询(oracle,mysql,sql)
- Oracle11G新增Impdp/Empdp备份恢复命令使用详解
- Oracle数据库PrepareStatement查不到结果
- oracle 临时表
- ORACLE 11gR2 DG(Physical Standby)日常维护01
- Oracle 常用的查询语句
- Oracle 10G如何从recovery catalog中Unregister目标数据库
- oracle-sql-union用法
- mint安装oracle
- oracle pl/sql之sql语法
- oracle导出单用户下所有对象
- ORACLE 全文索引功能实现学习笔记
- [置顶] [实验-视频过程]oracle热备份-单个表空间-备份和恢复操作演示
- oracle 第14章 表空间管理