zoukankan      html  css  js  c++  java
  • 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下一个值
  • 相关阅读:
    木有晚餐吃的教训暴力图的时候
    HDU1231最大连续子序列DP
    java连连看(GUI有进度条加背景音乐)
    HDU2064简单hanno塔
    HDU1232并查集入门(畅通工程)
    HDU3460Ancient Printer(trie)
    在window下搭建php+apche+masql的方法(个人的蛋疼经历,绝对可靠)
    Java学生管理系统(GUI)(又写了这种破玩意儿了老师,放过我们吧,能不能来点新意)
    VUE使用elpagination添加分页功能
    JS 中深拷贝的几种实现方法
  • 原文地址:https://www.cnblogs.com/rinack/p/10558555.html
Copyright © 2011-2022 走看看