mysql如何实现自增序列
时间:2021-06-15
来源:互联网
今天PHP爱好者给大家带来本篇文章给大家介绍一下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;
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.测试添加实例 执行sql
INSERT INTO sequence VALUES ('testSeq', 0, 1);-- 添加一个sequence名称和初始值,以及自增幅度
SELECT SETVAL('testSeq', 10);-- 设置指定sequence的初始值
SELECT CURRVAL('testSeq');-- 查询指定sequence的当前值
SELECT NEXTVAL('testSeq');-- 查询指定sequence的下一个值
以上就是mysql如何实现自增序列的详细内容,更多请关注php爱好者其它相关文章!
-
删除百度网盘kernel.dll怎么做-应该如何操作才能删除百度网盘kernel.dll 时间:2025-05-13
-
快速恢复bmm.dll文件丢失的方法-如何自动修复bmm.dll丢失问题 时间:2025-05-13
-
热血江湖dbghelp.dll丢失怎么办-如何解决热血江湖dbghelp.dll丢失问题 时间:2025-05-13
-
如何处理winpe下一点分区就蓝屏-winpe下一点分区就蓝屏怎么处理 时间:2025-05-13
-
怎么样才能还原别人打码的图片-如何还原别人打码的图片 时间:2025-05-13
-
蓝屏代码0xC0000221一键修复-电脑蓝屏提示代码0xC0000221怎么办 时间:2025-05-13
今日更新
-
html邮件是什么
阅读:18
-
一文带你深入剖析PHP
阅读:18
-
如何使用PHP中的trait能力
阅读:18
-
html中设置字体的属性有哪些
阅读:18
-
深入了解PHP中的反射机制
阅读:18
-
使用HTML5的5大原因是什么
阅读:18
-
一分钟解读js与PHP 设置cookie的相互读取(附代码)
阅读:18
-
什么是正则表达式?他的用法?他的特点是什么?(附详解)
阅读:18
-
一招解决PHP5的笔记之(COOKIE与SESSION篇)(分享)
阅读:18
-
HTML中怎么去除列表项符号
阅读:18