mysql实现sequence功能的代码
更新时间:2019年03月14日 11:06:11 作者:江上一叶舟
今天小编就为大家分享一篇关于mysql实现sequence功能的代码,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
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');
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。如果你想了解更多相关内容请查看下面相关链接
相关文章
MySQL、Oracle数据库如何查看最大连接数和当前连接数
在使用MySQL、Oracle数据库时了解最大连接数和当前数据库连接数对于优化数据库性能和确保系统稳定性非常重要,这篇文章主要给大家介绍了关于MySQL、Oracle数据库如何查看最大连接数和当前连接数的相关资料,需要的朋友可以参考下2024-04-04mysql Out of memory (Needed 16777224 bytes)的错误解决
至于我改的这几个值是不是正确的解决方法,目前还不知道。先贴出来2012-07-07Windows7下安装使用MySQL8.0.16修改密码、连接Navicat问题
这篇文章主要介绍了Windows7下安装使用MySQL8.0.16修改密码、连接Navicat问题,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下2019-06-06通过实例解析MySql CURRENT_TIMESTAMP函数
这篇文章主要介绍了通过实例解析MySql CURRENT_TIMESTAMP函数,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下2020-09-09ubuntu server配置mysql并实现远程连接的操作方法
下面小编就为大家分享一篇ubuntu server配置mysql并实现远程连接的操作方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2017-12-12
最新评论