oracle数据库迁移至mysql 之 序列替换

    在mysql中没有序列,所以在迁移过程中oracle得序列需要用mysql的一个表和一个函数来替换

序列

SELECT SS_SEQS.NEXTVAL FROM DUAL

替换为一个表和一个函数

表如下:

create table SS_SEQS(

 idval int unsigned auto_increment,

 primary key (idval)

) engine=InnoDB AUTO_INCREMENT=10000;

函数如下:

delimiter $$

create function SS_SEQS_nextval()

returns integer

contains SQL

begin

declare id long;

insert into SS_SEQS() values();

select last_insert_id() into id;

if(id=100000) then

    set id=10000;

end if;

return id;

end;

$$

delimiter ;

使用方法如下即可取得序列值。

select SS_SEQS_nextval();

 

 

2012-04-28修改,解决自增长到最大值时从初始值循环增长。

上面中函数中循环判断不能使auto_increment真正从初始值10000开始重新开始。

设定auto_increment初始值语句应该是alter  table  SS_SEQS set auto_increment=10000;

但是这样还有一个问题,alter table放在函数中,新建函数的时候无法执行。所以重新换了个下面的方法。

 

表如下:

create table SS_SEQS(

 idval int unsigned,

 primary key (idval)

) engine=InnoDB;

 

Insert into SS_SEQS values(10000);

函数如下:

delimiter $$

create function SS_SEQS_nextval()

returns integer

contains SQL

begin

declare id long;

update SS_SEQS set idval=last_insert_id(idval+1);

select last_insert_id() into id;

if(id=99999) then

update SS_SEQS set idval=9999;

end if;

return id;

end;

$$

delimiter ;

使用方法如下即可取得序列值。

select SS_SEQS_nextval();

要将 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、付费专栏及课程。

余额充值