mysql 怎样实现序列自增 超详细的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;

mysql 怎样实现序列自增 超详细的mysql数据库创建自增序列实现过程(1)



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 ;

mysql 怎样实现序列自增 超详细的mysql数据库创建自增序列实现过程(2)



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 ;

mysql 怎样实现序列自增 超详细的mysql数据库创建自增序列实现过程(3)



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的下一个值

mysql 怎样实现序列自增 超详细的mysql数据库创建自增序列实现过程(4)


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


觉得有用的朋友多帮忙转发哦!后面会分享更多devops和DBA方面的内容,感兴趣的朋友可以关注下~


mysql 怎样实现序列自增 超详细的mysql数据库创建自增序列实现过程(5)

,

免责声明:本文仅代表文章作者的个人观点,与本站无关。其原创性、真实性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容文字的真实性、完整性和原创性本站不作任何保证或承诺,请读者仅作参考,并自行核实相关内容。文章投诉邮箱:anhduc.ph@yahoo.com

    分享
    投诉
    首页