• MySql实现sequence功能的代码


    使用函数创建自增序列管理表(批量使用自增表,设置初始值,自增幅度)

    第一步:创建Sequence管理表 sequence

    DROP TABLE IF EXISTS sequence;
    CREATE TABLE sequence (
        NAME VARCHAR ( 50 ) NOT NULL, 
        current_value INT NOT NULL, 
        increment INT NOT NULL DEFAULT 1, 
        PRIMARY KEY ( NAME ) 
    ) ENGINE = INNODB;

    第二步:创建取当前值的函数 currval

    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;

    第三步:创建取下一个值的函数 nextval

    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;

    第四步:创建更新当前值的函数 setval

    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;

    测试函数功能

    当上述四步完成后,可以用以下数据设置需要创建的sequence名称以及设置初始值和获取当前值和下一个值。

    INSERT INTO sequence VALUES ('TestSeq', 0, 1);
    ----添加一个sequence名称和初始值,以及自增幅度  添加一个名为TestSeq 的自增序列
    
    SELECT SETVAL('TestSeq', 10);
    ---设置指定sequence的初始值    这里设置TestSeq 的初始值为10
    
    SELECT CURRVAL('TestSeq');  
    --查询指定sequence的当前值   这里是获取TestSeq当前值
    
    SELECT NEXTVAL('TestSeq');  
    --查询指定sequence的下一个值  这里是获取TestSeq下一个值
    INSERT INTO sequence VALUES ('TestSeq',0,1);----添加一个sequence名称和初始值,以及自增幅度添加一个名为TestSeq的自增序列
    
    SELECT SETVAL('TestSeq',10);---设置指定sequence的初始值这里设置TestSeq的初始值为10
    
    SELECT CURRVAL('TestSeq');--查询指定sequence的当前值这里是获取TestSeq当前值
    
    SELECT NEXTVAL('TestSeq');--查询指定sequence的下一个值这里是获取TestSeq下一个值
  • 相关阅读:
    Alpha 冲刺 (8/10)
    Alpha 冲刺 (7/10)
    Alpha 冲刺 (6/10)
    团 队 作 业 ———— 随 堂 小 测
    Alpha 冲刺 (5/10)
    Alpha 冲刺 (4/10)
    Beta冲刺博客汇总(麻瓜制造者)
    Beta冲刺(3/5)(麻瓜制造者)
    快速搭建一个Express工程骨架
    个人作业——软件产品案例分析
  • 原文地址:https://www.cnblogs.com/rinack/p/10558555.html
Copyright © 2020-2023  润新知