mysql 实现nextval_mysql实现nextVal功能
首先創(chuàng)建表:
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)
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 ;
查詢當(dāng)前記錄:
select currval('TBL_FS');如果出現(xiàn)Error Code: 1449 The user specified as a definer ('root'@'%') does not exist
錯誤,則執(zhí)行如下sql:
grant all privileges on *.* to root@"%" identified by "password";
flush privileges;
繼續(xù)執(zhí)行當(dāng)前記錄sql則成功
創(chuàng)建nextval函數(shù)
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$$
執(zhí)行nextval函數(shù)
select nextval('tbl_fs')
總結(jié)
以上是生活随笔為你收集整理的mysql 实现nextval_mysql实现nextVal功能的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 6寸是多少厘米(一寸等于多少厘米)
- 下一篇: linux cmake编译源码,linu