基于MySQL数据库实现序列自增功能

 概述

由于mysql和oracle不太一样,基于据库不支持直接的数实现sequence,所以需要创建一张table来模拟sequence的序列功能。

1、自增创建sequence表

CREATE TABLE `sequence` (     `name` VARCHAR ( 50 ) COLLATE utf8_bin NOT NULL COMMENT 序列的基于据库名字,     `current_value` INT ( 11 ) NOT NULL COMMENT 序列的当前值,     `increment` INT ( 11 ) NOT NULL DEFAULT 1 COMMENT 序列的自增值, PRIMARY KEY ( `name` )  ) ENGINE = INNODB DEFAULT CHARSET = utf8 COLLATE = utf8_bin;

2、创建–取当前值的数实现函数

DROP FUNCTION IF EXISTS currval;  DELIMITER $  CREATE FUNCTION currval (seq_name 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 name = seq_name;   RETURN value;  END $  DELIMITER ;

3、站群服务器创建–取下一个值的序列函数

DROP FUNCTION IF EXISTS nextval;  DELIMITER $  CREATE FUNCTION nextval (seq_name VARCHAR(50))   RETURNS INTEGER   LANGUAGE SQL   DETERMINISTIC   CONTAINS SQL   SQL SECURITY DEFINER   COMMENT   BEGIN   UPDATE sequence   SET current_value = current_value + increment   WHERE name = seq_name;   RETURN currval(seq_name);  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 ;

5、测试

INSERT INTO sequence VALUES (hwb_Seq,基于据库 0, 1);--添加一个sequence名称和初始值,以及自增幅度 SELECT SETVAL(hwb_Seq,数实现 10);--设置指定sequence的初始值 SELECT CURRVAL(hwb_Seq);--查询指定sequence的当前值 SELECT NEXTVAL(hwb_Seq);--查询指定sequence的下一个值

这里,hwb_Seq可以认为是序列一个表名,服务器托管通过insert语句插入指定表的自增第一个序列,然后使用NEXTVAL方法,基于据库不断更新这一列数据,数实现来获取下一个序列的序列值。可以通过这张表,来实现N张表的自增序列的统一管理。

云服务器
应用开发
上一篇:光学数据中心:为什么它是未来数据中心的需要?
下一篇:北京电信发布基于昇腾自主创新的“AI智算中心”,开创数字经济新时代