mysql自增序列 sequence

当前数据库为:mysql
由于mysql,不支持直接的sequence,所以需要创建一张table来模拟sequence的功能,理由sql语句如下:
第一步:创建--Sequence 管理表


 
DROP TABLE IF EXISTS sequence ;
CREATE TABLE sequence_tbl (
      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_tbl VALUES ('TestSeq', 0, 1);----添加一个sequence名称和初始值,以及自增幅度
  • SELECT SETVAL('TestSeq', 10000);---设置指定sequence的初始值
  • SELECT CURRVAL('TestSeq');--查询指定sequence的当前值
  • SELECT NEXTVAL('TestSeq');--查询指定sequence的下一个值

 

 
在java代码中,可直接创建sql语句查询下一个值,这样就解决了流水号唯一的问题。
贴出部分代码(已测试通过)


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
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);
   }
}

 

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值