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下一个值
  • 相关阅读:
    Redis中的批量删除数据库中的Key
    Solr中初学Demo
    Solr中Schema.xml中文版
    Eclipse中web项目的默认发布路径改为外部Tomcat中webapp路径
    Java操作XML的工具类
    Java中创建操作文件和文件夹的工具类
    Java中的操作日期的工具类
    Java POI操作Excle工具类
    【转】怎样写一个解释器
    【转】什么是语义学
  • 原文地址:https://www.cnblogs.com/rinack/p/10558555.html
Copyright © 2011-2022 走看看