mysql实现nextVal功能,即使用代理表实现其他表的主键自增长
来源:SegmentFault
时间:2023-01-13 08:48:34 342浏览 收藏
本篇文章给大家分享《mysql实现nextVal功能,即使用代理表实现其他表的主键自增长》,覆盖了数据库的常见基础知识,其实一个语言的全部知识点一篇文章是不可能说完的,但希望通过这些问题,让读者对自己的掌握程度有一定的认识(B 数),从而弥补自己的不足,更好的掌握它。
首先创建表:CREATE TABLE
sys_sequence(
NAMEvarchar(50) NOT NULL,
CURRENT_VALUEint(11) NOT NULL DEFAULT '0',
INCREMENTint(11) NOT NULL DEFAULT '1',
PRIMARY KEY (
NAME)
)
插入记录:INSERT INTO SYS_SEQUENCE(NAME,CURRENT_VALUE,INCREMENT) VALUES('TBL_FS', 1,1)
执行函数:DELIMITER $$
DROP FUNCTION IF EXISTS
currval$$
CREATE DEFINER=
root@
%FUNCTION
currval(seq_name VARCHAR(50)) RETURNS INT(11)
BEGIN
DECLARE VALUE INTEGER;
SET VALUE=0;
SELECT current_value INTO VALUE
FROM sys_sequence
WHERE NAME=seq_name;
RETURN VALUE;
END$$
DELIMITER ;
查询记录:select currval('TBL_FS');
如果出现Error Code: 1449 The user specified as a definer ('root'@'%') does not exist 错误,则执行如下sql:grant all privileges on . to root@"%" identified by "password";
flush privileges;
继续执行当前记录sql则成功
创建nextval函数 :
DELIMITER $$
DROP FUNCTION IF EXISTS
nextval$$
CREATE DEFINER=
root@
%FUNCTION
nextval(seq_name varchar(50)) RETURNS int(11)
BEGIN
UPDATE sys_sequence
SET CURRENT_VALUE = CURRENT_VALUE + INCREMENT
where name=seq_name;
return currval(seq_name);
END$$
创建好了表之后 :如图

NAME字段为代理表名称,原来为 TBL_FS,此处我修改了,current_value为当前序号,INCREMENT为步长。
接下来在mybatis配置文件目录下创建mapper文件:
/p>
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
接下来在service层写对应的获取数据方法:
@Service
public class MySQLFunctionServiceImpl implements MySQLFunctionService{
@Resource(name = "daoSupport")
private DaoSupport dao; //DaoSupport封装了对应mybatis操作数据库的方法,上篇文章有介绍
@Override
public int getNexVal(String table_name) {
// TODO Auto-generated method stub
return (int) dao.findForObject("MySQLFunctionMapper.getNexVal", table_name);
}
@Override
public int getCurrVal(String table_name) {
// TODO Auto-generated method stub
return (int) dao.findForObject("MySQLFunctionMapper.getCurrVal", table_name);
}
}
这样就可以调用getNexVal方法获取代理表中的ID值,再对应赋值到其他表的主键中,一般可在controller调用给其他表的主键赋值后存入数据库
终于介绍完啦!小伙伴们,这篇关于《mysql实现nextVal功能,即使用代理表实现其他表的主键自增长》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布数据库相关知识,快来关注吧!
-
499 收藏
-
244 收藏
-
235 收藏
-
157 收藏
-
101 收藏
-
数据库 · MySQL | 1天前 | 性能优化 · 高并发 · InnoDB · MySQL教程 · 数据库运维 · mysql innodb AUTO_INCREMENT 高并发写入 innodb_autoinc_lock_mode254 收藏
-
数据库 · MySQL | 1天前 | 连接池 · 高并发 · 故障排查 · MySQL教程 · 数据库运维 · mysql 高并发 连接池 max_connections Too many connections491 收藏
-
381 收藏
-
数据库 · MySQL | 2天前 | 性能优化 · InnoDB · 故障排查 · MySQL教程 · DBA实战 · mysql innodb 性能优化 预热 冷启动 MySQL 8.4 Buffer Pool158 收藏
-
数据库 · MySQL | 2天前 | binlog · 故障恢复 · 备份恢复 · MySQL教程 · DBA实战 · mysql DBA binlog 备份恢复 mysqlbinlog MySQL 8.4 PITR432 收藏
-
数据库 · MySQL | 2天前 | 字符集 · 故障排查 · MySQL教程 · 索引优化 · 排序规则 · mysql 排序规则 索引优化 utf8mb4 collation MySQL 8.4294 收藏
-
数据库 · MySQL | 2天前 | binlog · 主从复制 · 故障排查 · MySQL教程 · DBA实战 · mysql DBA binlog 主从复制 MySQL 8.4 复制延迟 relay log119 收藏
-
数据库 · MySQL | 2天前 | MySQL教程 · 慢查询治理 · 索引优化 · 分区表 · DBA实战 · mysql 分区表 慢查询 索引优化 MySQL 8.4 partition pruning133 收藏
-
数据库 · MySQL | 2天前 | 高并发 · 故障排查 · MySQL教程 · 事务隔离 · InnoDB锁 · mysql innodb 高并发 锁等待 MySQL 8.4 NOWAIT SKIP LOCKED439 收藏
-
291 收藏
-
数据库 · MySQL | 3天前 | InnoDB · 故障排查 · 生产实践 · MySQL教程 · 事务隔离 · mysql innodb Purge Lag History List 长事务 Undo326 收藏
-
数据库 · MySQL | 3天前 | 性能优化 · 执行计划 · 生产实践 · MySQL教程 · 索引优化 · mysql explain 索引优化 Index Condition Pushdown ICP179 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习