博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
oracle序列
阅读量:6175 次
发布时间:2019-06-21

本文共 1051 字,大约阅读时间需要 3 分钟。

hot3.png

    1. oracle序列创建语法
CREATE SEQUENCE sequence  //创建序列名称       [INCREMENT BY n]  //递增的序列值是n 如果n是正数就递增,如果是负数就递减 默认是1       [START WITH n]    //开始的值,递增默认是minvalue 递减是maxvalue       [{MAXVALUE n | NOMAXVALUE}] //最大值       [{MINVALUE n | NOMINVALUE}] //最小值       [{CYCLE | NOCYCLE}] //循环/不循环       [{CACHE n | NOCACHE}];//分配并存入到内存中
    2. oracle创建语法中的缓存作用
       (参考:http://zhidao.baidu.com/link?url=5rNZnGdRJ9JPUVng3LrXtQ2pIuwTmpeEM4WRh7ibFWnXSJEDSKx1igdCEy0grG75wxH3WC5XOSaMK-e5k1xmOK)
       当大量语句发生请求,申请序列时,为了避免序列在运用层实现序列而引起的性能瓶颈。Oracle序列允许将序列提前生成 cache x个先存入内存,在发生大量申请序列语句时,可直接到运行最快的内存中去得到序列。但cache个数也不能设置太大,因为在数据库重启时,会清空内存信息,预存在内存中的序列会丢失,当数据库再次启动后,序列从上次内存中最大的序列号+1 开始存入cache x个。
    3. 序列的查询(以自增序列为例)
       创建自增序列:
create sequence s1 increment by 1 start with 1 maxvalue 999 cycle cache 10;
       <1> 普通查询     
select s1.nextval 普通序列号 from dual;
       <2> 固定格式的查询----位数补零          
select lpad(s1.nextval,3,'0') 补零序列号 from dual;
       <3> 当前时间与自增序列结合.         
select to_char(sysdate,'yyyyMMddHH24miss')||lpad(s1.nextval,3,'0') 时间与补零序列号 from dual;
    4. 序列的删除
       drop sequence 序列名称;

转载于:https://my.oschina.net/u/1989867/blog/539169

你可能感兴趣的文章
mysql备份方法(热备)
查看>>
scala匿名函数
查看>>
vlan技术【实现】vlan简介和SVI实现不同vlan间通信
查看>>
scrapy爬虫初步尝试
查看>>
陈松松:视频制作不出来,跟这7个思维有九成关系
查看>>
形参和实参有何区别
查看>>
我的友情链接
查看>>
MySQL表结构的导入和导出MySQL表结构的导入和导出
查看>>
JavaSE 学习参考:Map容器遍历
查看>>
salt模块命令
查看>>
基于TBDS的flume异常问题排查过程
查看>>
2017/5 JavaScript基础7--- 数组
查看>>
网络时常断网的解决办法
查看>>
第八次作业及答案
查看>>
linux 日志定时清理脚本
查看>>
java老司机面试题
查看>>
Guice AOP
查看>>
懒汉式单例
查看>>
java递归组装树形结构
查看>>
手把手教你自己写一个模糊搜索的下拉框
查看>>