DROP TABLE IF EXISTS sys_sequence ;
CREATE TABLE sys_sequence (
seq_name VARCHAR (50) NOT NULL,
curr_value BIGINT NOT NULL DEFAULT 0,
increment_by INT NOT NULL DEFAULT 1,
PRIMARY KEY (seq_name)
) ENGINE = INNODB ;
INSERT INTO sys_sequence VALUES ('SEQ_TEST_NO',10000,1);
DELIMITER $$
DROP FUNCTION IF EXISTS currval $$
CREATE
/*[DEFINER = { user | CURRENT_USER }]*/
FUNCTION currval(v_seq_name VARCHAR (50))
RETURNS BIGINT
/*LANGUAGE SQL
| [NOT] DETERMINISTIC
| { CONTAINS SQL | NO SQL | READS SQL DATA | MODIFIES SQL DATA }
| SQL SECURITY { DEFINER | INVOKER }
| COMMENT 'string'*/
BEGIN
DECLARE v_currval BIGINT;
SET v_currval = 1 ;
SELECT
curr_value INTO v_currval
FROM
sys_sequence
WHERE seq_name = v_seq_name ;
RETURN v_currval ;
END$$
DELIMITER ;
-- SELECT `currval`('SEQ_TEST_NO');
DELIMITER $$
DROP FUNCTION IF EXISTS `nextval` $$
CREATE FUNCTION `nextval` (`v_seq_name` VARCHAR (50)) RETURNS BIGINT (20) CONTAINS SQL
BEGIN
UPDATE
sys_sequence
SET
`curr_value` = last_insert_id(`curr_value` + `increment_by`)
WHERE `seq_name` = v_seq_name ;
RETURN last_insert_id();
END $$
DELIMITER ;
相关文章
- 04-15【题解】[Codeforces Gym 101224 F] Lonely Dreamoon 2 | 20210930 模拟赛 序列(sequence)
- 04-15在MySQL中创建实现自增的序列(Sequence)的教程
- 04-15mysql实现oracle sequence方案
- 04-15MySQL实现类似Oracle的序列
- 04-15oracle 序列sequence
- 04-15Oracle 序列(sequence)
- 04-15Oracle序列(Sequence)创建、使用、修改、删除
- 04-15oracle数据库--序列(sequence)
- 04-15Oracle新表使用序列(sequence)作为插入值,初始值不是第一个,oraclesequence
- 04-15DB2序列(sequence)转成mysql 序列