«

java基于数据库怎么实现全局唯一ID

时间:2024-6-14 09:34     作者:韩俊     分类: Java


本篇内容主要讲解“java基于数据库怎么实现全局唯一ID”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“java基于数据库怎么实现全局唯一ID”吧!

一、原理

  在数据库中建立ID序列表记录ID值,其中包含两个重要字段,一个是初始值,另一个是步幅。建立表如下:

二、建立sql函数

 其分别sql语句为:

currval函数

CREATE DEFINER=`root`@`localhost` FUNCTION `currval`(`keyname` varchar(50)) RETURNS int
BEGIN
   DECLARE v int;
     SET v=0;
     SELECT CURR_VAL INTO v from sequence WHERE SEQNAME=keyname;
     RETURN v;
END

nextval函数

CREATE DEFINER=`root`@`localhost` FUNCTION `nextval`(seq VARCHAR(50)) RETURNS int
BEGIN
   UPDATE sequence SET CURR_VAL=CURR_VAL+INCREMENT_VAL WHERE SEQNAME=seq;
     RETURN currval(seq);
END

三、xml中查询当前ID

select nextval(#{seq})

标签: java

热门推荐