项目应用中,现在有这样的场景,之前用的Oracle,现在要转Mysql。由于mysql和oracle不太一样,不支持直接的sequence,所以需要创建一张table来模拟sequence的功能:
-- 第一步:创建--Sequence 管理表 (我的流水号是Long类型 所以用bigint,可根据实际需要更改类型即可)
current_value:指初始值; increment:指自增幅度;
DROP TABLE IF EXISTS sequence;
CREATE TABLE sequence (
name VARCHAR(50) NOT NULL,
current_value bigint NOT NULL,
increment bigint NOT NULL DEFAULT 1,
PRIMARY KEY (name)
) ENGINE=InnoDB;
-- 第二步:创建--取当前值的函数
DROP FUNCTION IF EXISTS currval;
DELIMITER $
CREATE FUNCTION currval (seq_name VARCHAR(50))
RETURNS INTEGER
LANGUAGE SQL
DETERMINISTIC
CONTAINS SQL
SQL SECURITY DEFINER