【MYSQL】数据库序列相关整理

1. 数据库序列的应用场景:

  • 序列用在父表主键的生成中, 同时主键也是子表的外键
insert into parent_table(id) values(seq1.nextval);
insert into child_table(pid) values(seq1.currval);

2.序列的相关描述

  • 提供的一个产生唯一数值型值的机制。通常用于表的主健值,序列只能保证唯一,不能保证连续。
  • 序列并不占用实际的存储空间
  • 使用序列时,需要用到序列的两个伪列NEXTVAL与CURRVAL。其中,NEXTVAL将返回序列生成的下一个值,而CURRVAL返回序列的当前值

3.序列的实现

  • 创建序列表
CREATE TABLE `sys_sequence` (
   `NAME` varchar(50) NOT NULL,  -- 序列名称
   `CURRENT_VALUE` int(11) NOT NULL DEFAULT '0', -- 当前序列值
   `INCREMENT` int(11) NOT NULL DEFAULT '1', -- 序列每次增长的幅度
   PRIMARY KEY (`NAME`) 
 )
  • 插入序列值
INSERT INTO SYS_SEQUENCE(NAME,CURRENT_VALUE,INCREMENT) VALUES('TBL_FS', 1,1)
  • 创建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
  • 创建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
  • 执行CURRVAL函数
select currval('TBL_FS');
  • 执行NEXTVAL函数
select nextval('tbl_fs')

-------------------------------------------------------------------------------------------------------------------------------------

注:小白的我遇到问题总结

  • FUNCTION test.nextval does not exist

        错误原因:没有在test库中,创建nextval函数!

                       个人理解mysql中应该会自带一些常用函数,nextval不是自带的需要自己设置一下!

  • The user specified as a definer ('root'@'%') does not exist

        错误原因:此种报错主要是针对访问视图文件引起的(没有权限)

        解决方法:打开mysql命令客服端

       

权限问题,授权 给 root  所有sql 权限:

 grant all privileges on *.* to root@"%" identified by ".";

刷新权限:

flush privileges;

欢迎留言补充相关内容!~

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值