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;
欢迎留言补充相关内容!~