首页 / MYSQL / MySQL获取自增序列
MySQL获取自增序列
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了MySQL获取自增序列,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2523字,纯文字阅读大概需要4分钟。
内容图文
![MySQL获取自增序列](/upload/InfoBanner/zyjiaocheng/890/bcd2f54ec64e4385a75a3897a4c79981.jpg)
因为业务要求,需要在MySQL数据库中,获取下一个自增主键的值。
原先采用的方法是:
select AUTO_INCREMENT FROM information_schema.TABLES WHERE TABLE_SCHEMA = '数据库名称' AND TABLE_NAME = '表名称' limit 1
但是这样写的话,在8.0以后的版本是取不到值的,必须在每一次需要获取自增序列之前,多执行一条表分析的语句。然后语句就会变成下面这样:
ANALYZE TABLE 表名;
select auto_increment FROM information_schema.tables
WHERE TABLE_SCHEMA = '库名' AND TABLE_NAME = '表名' limit 1;
这样写会造成一个问题,当表中的数据较多的时候,会造成查询的速度变慢。
因此,就要使用另外一个策略,就是自己创建一个自增序列。
这里参考了 mysql 中创建自增的序列(Sequence)
由于mysql和oracle不太一样,不支持直接的sequence,所以需要创建一张table来模拟sequence的功能。
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.使用及测试
INSERT INTO sequence VALUES ('testSeq', 0, 1);--添加一个sequence名称和初始值,以及自增幅度
SELECT SETVAL('testSeq', 10);--设置指定sequence的初始值
SELECT CURRVAL('testSeq');--查询指定sequence的当前值
SELECT NEXTVAL('testSeq');--查询指定sequence的下一个值
这里,testSeq可以认为是一个表名,我们可以通过insert语句插入指定表的第一个序列,然后使用NEXTVAL方法,不断更新这一列数据,来获取下一个序列的值。可以通过这张表,来实现N张表的自增序列的统一管理。
内容总结
以上是互联网集市为您收集整理的MySQL获取自增序列全部内容,希望文章能够帮你解决MySQL获取自增序列所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。