mysql模拟oracle序列

/*****************************************
由于mysql和oracle不太一样,不支持直接的sequence,所以需要创建一张table来模拟sequence的功能
*****************************************/
/* 1. 创建--Sequence 管理表*/
DROP TABLE IF EXISTS sequence;
CREATE TABLE sequence (
  seq_name VARCHAR(50) NOT NULL  COMMENT '序列名称',
  current_value INT NOT NULL COMMENT '当前值',
  increment INT NOT NULL DEFAULT 1 COMMENT '步长',
  PRIMARY KEY (seq_name)
) ENGINE=InnoDB;
/* 2. 创建--取当前值的函数*/
DROP FUNCTION IF EXISTS currval;
DELIMITER $
CREATE FUNCTION currval(seqName VARCHAR(50))
  RETURNS INTEGER
LANGUAGE SQL
DETERMINISTIC
CONTAINS SQL
  SQL SECURITY DEFINER
  COMMENT ''
  BEGIN
    DECLARE value INTEGER;
    SET value = 0;
    SELECT current_value INTO value
    FROM sequence
    WHERE seq_name = seqName;
    RETURN value;
  END
$
DELIMITER ;
/* 3. 创建--取下一个值的函数*/
DROP FUNCTION IF EXISTS nextval;
DELIMITER $
CREATE FUNCTION nextval (seqName VARCHAR(50))
  RETURNS INTEGER
LANGUAGE SQL
DETERMINISTIC
CONTAINS SQL
  SQL SECURITY DEFINER
  COMMENT ''
  BEGIN
    UPDATE sequence
    SET current_value = current_value + increment
    WHERE seq_name = seqName;
    RETURN currval(seqName);
  END
$
DELIMITER ;
/* 4. 创建--更新当前值的函数*/
DROP FUNCTION IF EXISTS setval;
DELIMITER $
CREATE FUNCTION setval (seq_name VARCHAR(50), value INTEGER)
  RETURNS INTEGER
LANGUAGE SQL
DETERMINISTIC
CONTAINS SQL
  SQL SECURITY DEFINER
  COMMENT ''
  BEGIN
    UPDATE sequence
    SET current_value = value
    WHERE name = seq_name;
    RETURN currval(seq_name);
  END
$
DELIMITER ;
  • INSERT INTO sequence VALUES ('TestSeq', 0, 1);----添加一个sequence名称和初始值,以及自增幅度
  • SELECT SETVAL('TestSeq', 10);---设置指定sequence的初始值
  • SELECT CURRVAL('TestSeq');--查询指定sequence的当前值
  • SELECT NEXTVAL('TestSeq');--查询指定sequence的下一个值
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值