oracle序列

    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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要将 Oracle 序列迁移到 MySQL,需要考虑到两个数据库之间的差异。在 Oracle 中,序列是自动递增的整数值生成器,而 MySQL 中没有直接的序列类型。以下是一个迁移序列的一般步骤: 1. 创建一个 MySQL 表来模拟序列:在 MySQL 中,您可以创建一个包含一个自增列的表来模拟序列。例如,创建一个名为 `sequence_table` 的表,其中包含一个名为 `sequence_value` 的自增列。 2. 导出 Oracle 序列的当前值:使用 Oracle SQL 查询来获取序列的当前值。例如,对于名为 `my_sequence` 的序列,您可以运行如下查询:`SELECT my_sequence.CURRVAL FROM dual;`。 3. 将导出的当前值插入到模拟序列表中:将步骤 2 中导出的序列当前值插入到 MySQL 的模拟序列表中。 例如,使用以下查询将序列当前值插入到 `sequence_table` 表中: ```sql INSERT INTO sequence_table (sequence_value) VALUES (<当前值>); ``` 4. 创建一个在 MySQL 中自增的列:在需要使用序列的 MySQL 表中,创建一个自增列,以模拟 Oracle 序列的行为。例如,创建一个名为 `id` 的自增列。 5. 更新表的自增列的起始值:使用 `ALTER TABLE` 语句来更新自增列的起始值,以与步骤 2 中导出的当前值匹配。 例如,使用以下查询将 `id` 列的起始值更新为模拟序列表中的当前值: ```sql ALTER TABLE your_table AUTO_INCREMENT = <当前值>; ``` 现在,您可以使用 MySQL 表中的自增列来模拟 Oracle 序列的行为。请注意,这只是一种模拟方法,可能无法完全复制 Oracle 序列的所有行为。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值