工作过程中需要将基于DB2数据库的应用以及数据迁移到MySQL中去,在原应用中,大量使用了SEQUENCE,考虑尽量减少代码的修改,决定在迁移后的应用中继续保留SEQUENCE的使用,这就要求在MySQL中寻找替代SEQUENCE的解决方案。
在DB2中创建一个SEQUENCE的方法如下:
DROPSEQUENCE TRZ_MEMBER.SEQ_TRZ_MEMBER_NO;CREATESEQUENCE TRZ_MEMBER.SEQ_TRZ_MEMBER_NOAS BIGINTINCREMENTBY 1STARTWITH 10000000000MAXVALUE99999999999NO CYCLE
CACHE20
ORDER;
MySQL自增长与Oracle(DB2)序列的区别:
自增长只能用于表中的其中一个字段;
自增长只能被分配给固定表的固定的某一字段,不能被多个表共用;
自增长会把一个未指定或NULL值的字段自动填上。
要想在MySQL中替代SEQUENCE功能需要做一下几件事:
1:建立SEQUENCE表,存储多条SEQUENCE信息;
2:完成自定义函数的定义,在程序中通过该函数完成生成的序列的获取;
接下来将介绍两种生成方式,一种是非并发方式,一种是并发方式,前一种不能够处理并发访问中存在的问题,后一种则能够处理,两种方式的第一步都相同,就是创建SEQUENCE表:
非并发方式:
一:创建SEQUENCE表:
DROP TABLE
IF EXIST