温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

MySQL数据库中怎么实现序列自增功能

发布时间:2021-07-13 16:09:04 来源:亿速云 阅读:799 作者:Leah 栏目:数据库

MySQL数据库中怎么实现序列自增功能,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

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数据库中怎么实现序列自增功能

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数据库中怎么实现序列自增功能

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数据库中怎么实现序列自增功能

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数据库中怎么实现序列自增功能的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注亿速云行业资讯频道,感谢各位的阅读!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI