MySQL中实现自增序列的方法是什么?
导读:这篇文章给大家分享的是MySQL中实现自增序列的方法,数据库实现自增序列还是比较实用的,不需要我们再手动设置,非常方便,那么具体怎样做呢?文中介绍的非常详细,感兴趣的朋友接下来一起跟随小编看看吧。1.创建sequence表CREATE TA...
这篇文章给大家分享的是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中实现自增序列的方法,上述方法具有一定的参考价值,有需要的朋友可以了解看看,希望对大家学习mysql数据有帮助,想要了解更多可以继续浏览网络其他相关的文章。
文本转载自PHP中文网
声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!
若转载请注明出处: MySQL中实现自增序列的方法是什么?
本文地址: https://pptw.com/jishu/652208.html
