1、oracel可以直接支持sequence,但是mysql不支持sequence,因此我们要通过模拟sequence的方法在mysql中创建sequence。
模拟sequence的方法:
项目场景:
项目应用中,曾有以下一个场景:

接口中要求发送一个int类型的流水号,由于多线程模式,如果用时间戳,可能会有重复的情况(当然概率很小)。

所以想到了利用一个独立的自增的sequence来解决该问题。

当前数据库为:mysql

由于mysql和oracle不太一样,不支持直接的sequence,所以需要创建一张table来模拟sequence的功能,sql语句如下:
第一步:创建--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;

第二步:创建--取当前值的函数
    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 ;

第三步:创建--取下一个值的函数
    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 ;

第四步:创建--更新当前值的函数
    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名称和初始值,以及自增幅度
SELECT SETVAL('TestSeq', 10);---设置指定sequence的初始值
SELECT CURRVAL('TestSeq');--查询指定sequence的当前值
SELECT NEXTVAL('TestSeq');--查询指定sequence的下一个值

在java代码中,可直接创建sql语句查询下一个值,这样就解决了流水号唯一的问题。

贴出部分代码(已测试通过)
    public void testGetSequence() {  
        Connection conn = JDBCUtils.getConnection(url, userName, password);  
        String sql = "SELECT CURRVAL('TestSeq');";  
        PreparedStatement ptmt = null;  
        ResultSet rs = null;  
        try {  
            ptmt = conn.prepareStatement(sql);  
            rs = ptmt.executeQuery();  
            int count = 0;  
            while (rs.next()) {  
                count = rs.getInt(1);  
            }  
            System.out.println(count);  
        } catch (SQLException e) {  
            e.printStackTrace();  
        } finally {  
            JDBCUtils.close(rs, ptmt, conn);  
        }  
    }

ps:在应用中,还有一种用java代码去实现模拟自增sequence的方式,具体思路是创建一张存放sequence的table,然后通过java调用sql语句去查询和修改这个table中指定sequence名称的值,这种方式请加上synchronized。具体代码这里就不上传了,因为实现了,未去测试过。

【转】MySQL中增加sequence管理功能(模拟创建sequence)的更多相关文章

  1. JOffice中的权限管理--功能粒度的权限管理配置

    JOffice中的权限管理是基于角色的管理策略,采用Spring Security2的配置方式,同时能够结合EXT3来进行整个系统的权限管理,通过使用配置文件,进行整个系统的功能集中管理,包括系统左边 ...

  2. elasticsearch 7.x 如何满足mysql中的模糊查询功能(like)

    业务场景:筛选项原功能是用mysql左模糊进行过滤查询,现业务要用es,怎么样才能满足原功能,又不损性能. elasticsearch中有关于模糊查询的操作:wildcard 文档:https://b ...

  3. VuePress 中增加用户登录功能

    在 VuePress 中增加用户登录 VuePress 是 Vuejs 官方提供的一个快速建设文档站点的工具,在简单配置好功能后,需要做的事情就剩下写好一个个 Markdown 文档. 因为 VueP ...

  4. sql server和mysql中分别实现分页功能

    MySQL 在MySQL中,可以用 Limit 来查询第 m 列到第 n 列的记录, 例如: select * from tablename limit m, n sql="select * ...

  5. mysql中增加某一时间段内的时间数据(包含:时间、年、月、日、第几周、季度)

    创建表dim_date: create table `dim_date` ( `year` int (20), `month` int (20), `day` int (20), `week` int ...

  6. Django Admin中增加导出Excel功能

    参考: https://www.cnblogs.com/yoyo008/p/9232805.html 在使用Django Admin时, 对于列表我们有时需要提供数据导出功能, 如下图: 在Djang ...

  7. Django Admin中增加导出CSV功能

    参考: https://books.agiliq.com/projects/django-admin-cookbook/en/latest/export.html 在使用Django Admin时, ...

  8. 如何在MySQL中增加一列

    如果想在一个已经建好的表中添加一列,可以使用诸如: alter table TABLE_NAME add column NEW_COLUMN_NAME varchar(255) not null; 这 ...

  9. MySql中增加一列

    如果想在一个已经建好的表中添加一列,可以用诸如: alter table TABLE_NAME add column NEW_COLUMN_NAME varchar(20) not null; 这条语 ...

随机推荐

  1. winform之判断验证码,,附加验证码的一般处理程序

    这里用的一般处理程序画的验证码图片. 判断验证码步骤: ①先在一般处理程序中获取验证码(一般处理程序中session的调用→context.Session[]) string code = GetRn ...

  2. jS-模式之简单的订阅者和发布者模式

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  3. hdu1890 伸展树(区间反转)

    对于大神来说这题是水题.我搞这题花了快2天. 伸展树的优点有什么,就是树不管你怎么旋转序列是不会改变得,并且你要使区间反转,只要把第k大的点转到根结点,那么它的左子树就是要交换的区间[l,r),然后交 ...

  4. hdu3966 树链剖分+成段更新

    给你n个点,m条边,p次操作.n个点相连后是一棵树.每次操作可以是x 到 y 增加 z,或者减z,或者问当前点的值是多少. 可以将树分成链,每个点在线段树上都有自己的点,然后线段树成段更新一下. #p ...

  5. COLORBOX文档

    1,flash覆盖colorbox: 2,colorbox在ie中的位置和行为异常: 3,colorbox的位置和行为异常(不区分浏览器): 4,用colorbox显示外部文档时显示不正确: 5,在i ...

  6. 【POJ 2096】Collecting Bugs 概率期望dp

    题意 有s个系统,n种bug,小明每天找出一个bug,可能是任意一个系统的,可能是任意一种bug,即是某一系统的bug概率是1/s,是某一种bug概率是1/n. 求他找到s个系统的bug,n种bug, ...

  7. MyEclipse护眼模式、字体大小的调整

    1.Eclipse改变背景颜色 Windows menu --> Preference General -> Editors -> Text Editors(click),  在底部 ...

  8. 【codevs1409】 拦截导弹 2

    http://codevs.cn/problem/1409/ (题目链接) 题意 给出n个三维的导弹,每次拦截只能打x,y,z严格上升的若干个导弹,求最多能一次拦截下多少个导弹,以及最少拦截几次将所有 ...

  9. HDU 2896 病毒侵袭

    Problem Description 当太阳的光辉逐渐被月亮遮蔽,世界失去了光明,大地迎来最黑暗的时刻....在这样的时刻,人们却异常兴奋——我们能在有生之年看到500年一遇的世界奇观,那是多么幸福 ...

  10. 我对Padding Oracle Attack的分析和思考

    道哥的<白帽子讲web安全>有一章提到Padding Oracle Attack的攻击方式,据说这货在2011年的Pwnie Rewards上还被评为"最具价值的服务器漏洞&qu ...