香港云主机最佳企业级服务商!

ADSL拨号VPS包含了中国大陆(联通,移动,电信,)

中国香港,国外拨号VPS。

当前位置:云主机 > MYSQL >

电信ADSL拨号VPS
联通ADSL拨号VPS
移动ADSL拨号VPS

mysql实现sequence功能的代码


时间:2020-11-03 13:39 作者:admin


mysql/' target='_blank'>mysql实现sequence功能

1.建立sequence记录表

CREATE TABLE `sys_sequence` ( `seq_name` varchar(50) CHARACTER SET latin1 COLLATE latin1_bin NOT NULL, `min_value` int(11) NOT NULL, `max_value` int(11) NOT NULL, `current_value` int(11) NOT NULL, `increment_value` int(11) NOT NULL DEFAULT '1', PRIMARY KEY (`seq_name`)) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

2.建立sequence基础函数

DELIMITER $$CREATE DEFINER=`root`@`%` FUNCTION `_nextval`(name varchar(50)) RETURNS int(11)begin declare _cur int;declare _maxvalue int; -- 接收最大值declare _increment int; -- 接收增长步数set _increment = (select increment_value from sys_sequence where seq_name = name);set _maxvalue = (select max_value from sys_sequence where seq_name = name);set _cur = (select current_value from sys_sequence where seq_name = name); update sys_sequence           -- 更新当前值set current_value = _cur + increment_value where seq_name = name ; if(_cur + _increment >= _maxvalue) then -- 判断是都达到最大值   update sys_sequence     set current_value = min_value     where seq_name = name ;end if;return _cur; end$$DELIMITER ;

3.插入想要建立的sequence

INSERT INTO `mydb`.`sys_sequence`(`seq_name`,`min_value`,`max_value`,`current_value`,`increment_value`)VALUES('seq_name1', 1, 99999999, 1, 1);

4.使用sequence

select _nextval('seq_name1');

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。如果你想了解更多相关内容请查看下面相关链接

(责任编辑:admin)






帮助中心
会员注册
找回密码
新闻中心
快捷通道
域名登录面板
虚机登录面板
云主机登录面板
关于我们
关于我们
联系我们
联系方式

售前咨询:17830004266(重庆移动)

企业QQ:383546523

《中华人民共和国工业和信息化部》 编号:ICP备00012341号

Copyright © 2002 -2018 香港云主机 版权所有
声明:香港云主机品牌标志、品牌吉祥物均已注册商标,版权所有,窃用必究

云官方微信

在线客服

  • 企业QQ: 点击这里给我发消息
  • 技术支持:383546523

  • 公司总台电话:17830004266(重庆移动)
  • 售前咨询热线:17830004266(重庆移动)