基于MySQL數(shù)據(jù)庫實現(xiàn)序列自增功能
概述
由于mysql和oracle不太一樣,不支持直接的sequence,所以需要創(chuàng)建一張table來模擬sequence的功能。
1、創(chuàng)建sequence表
- CREATE TABLE `sequence` (
- `name` VARCHAR ( 50 ) COLLATE utf8_bin NOT NULL COMMENT '序列的名字',
- `current_value` INT ( 11 ) NOT NULL COMMENT '序列的當(dāng)前值',
- `increment` INT ( 11 ) NOT NULL DEFAULT '1' COMMENT '序列的自增值',
- PRIMARY KEY ( `name` )
- ) ENGINE = INNODB DEFAULT CHARSET = utf8 COLLATE = utf8_bin;

2、創(chuàng)建–取當(dāng)前值的函數(shù)
- DROP FUNCTION IF EXISTS currval;
- DELIMITER $
- CREATE FUNCTION currval (seq_name VARCHAR(50))
- RETURNS INTEGER
- LANGUAGE SQL
- DETERMINISTIC
- CONTAINS SQL
- SQL SECURITY DEFINER
- COMMENT ''
- BEGIN
- DECLARE value INTEGER;
- SET value = 0;
- SELECT current_value INTO value
- FROM sequence
- WHERE name = seq_name;
- RETURN value;
- END
- $
- DELIMITER ;
3、創(chuàng)建–取下一個值的函數(shù)
- DROP FUNCTION IF EXISTS nextval;
- DELIMITER $
- CREATE FUNCTION nextval (seq_name VARCHAR(50))
- RETURNS INTEGER
- LANGUAGE SQL
- DETERMINISTIC
- CONTAINS SQL
- SQL SECURITY DEFINER
- COMMENT ''
- BEGIN
- UPDATE sequence
- SET current_value = current_value + increment
- WHERE name = seq_name;
- RETURN currval(seq_name);
- END
- $
- DELIMITER ;

4、創(chuàng)建–更新當(dāng)前值的函數(shù)
- DROP FUNCTION IF EXISTS setval;
- DELIMITER $
- CREATE FUNCTION setval (seq_name VARCHAR(50), value INTEGER)
- RETURNS INTEGER
- LANGUAGE SQL
- DETERMINISTIC
- CONTAINS SQL
- SQL SECURITY DEFINER
- COMMENT ''
- BEGIN
- UPDATE sequence
- SET current_value = value
- WHERE name = seq_name;
- RETURN currval(seq_name);
- END
- $
- DELIMITER ;

5、測試
- INSERT INTO sequence VALUES ('hwb_Seq', 0, 1);--添加一個sequence名稱和初始值,以及自增幅度
- SELECT SETVAL('hwb_Seq', 10);--設(shè)置指定sequence的初始值
- SELECT CURRVAL('hwb_Seq');--查詢指定sequence的當(dāng)前值
- SELECT NEXTVAL('hwb_Seq');--查詢指定sequence的下一個值

這里,hwb_Seq可以認為是一個表名,通過insert語句插入指定表的第一個序列,然后使用NEXTVAL方法,不斷更新這一列數(shù)據(jù),來獲取下一個序列的值??梢酝ㄟ^這張表,來實現(xiàn)N張表的自增序列的統(tǒng)一管理。