java數(shù)據(jù)庫唯一id生成工具類
更新時間:2019年04月21日 15:37:03 作者:Tlimited
這篇文章主要為大家詳細(xì)介紹了java數(shù)據(jù)庫唯一id生成工具類,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了java數(shù)據(jù)庫唯一id生成工具類的具體代碼,供大家參考,具體內(nèi)容如下
import java.io.File;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Map;
import java.util.Random;
import java.util.UUID;
import org.springframework.dao.EmptyResultDataAccessException;
import org.springframework.jdbc.core.JdbcTemplate;
public class UniqueIdUtil
{
private static long adjust = 1L;
private static long nextId = 0L;
private static long lastId = -1L;
private static long randomLeng = 6L;
private static JdbcTemplate jdbcTemplate;
private static SimpleDateFormat dateFormat = new SimpleDateFormat("yyyyMMddHHmmss");
private static void init()
{
try
{
jdbcTemplate = (JdbcTemplate)AppUtil.getBean("jdbcTemplateSN");
String str2 = AppConfigUtil.get("genId.adjust");
if (str2 != null) {
adjust = Integer.parseInt(str2);
}
}
catch (Exception localException)
{
adjust = 1L;
String str3 = AppConfigUtil.get("genId.adjust");
if (str3 != null) {
adjust = Integer.parseInt(str3);
}
}
}
private static void getNextIdBlock()
{
if (jdbcTemplate == null) {
init();
}
Long localLong = Long.valueOf(-1L);
Integer localInteger = Integer.valueOf(-1);
String str1 = "SELECT bound,incremental FROM SYS_DB_ID T WHERE T.ID=?";
String str2 = "UPDATE SYS_DB_ID SET BOUND=? WHERE ID=?";
try
{
Map localMap = jdbcTemplate.queryForMap(str1, new Object[] { Long.valueOf(adjust) });
localLong = Long.valueOf(Long.parseLong(localMap.get("bound").toString()));
localInteger = Integer.valueOf(Integer.parseInt(localMap.get("incremental").toString()));
nextId = localLong.longValue();
lastId = localLong.longValue() + localInteger.intValue();
jdbcTemplate.update(str2, new Object[] { Long.valueOf(lastId), Long.valueOf(adjust) });
}
catch (EmptyResultDataAccessException localEmptyResultDataAccessException)
{
insertNewComputer();
}
}
private static void insertNewComputer()
{
try
{
lastId = 10000L;
String str = "INSERT INTO SYS_DB_ID (id,incremental,bound) VALUES(" + adjust + ",10000," + lastId + ")";
jdbcTemplate.update(str);
}
catch (Exception localException)
{
localException.printStackTrace();
}
}
public static synchronized long genId()
{
if (lastId <= nextId) {
getNextIdBlock();
}
long l = nextId++;
return l + adjust * 10000000000000L;
}
public static final String getGuid()
{
UUID localUUID = UUID.randomUUID();
return localUUID.toString();
}
public static final String getRandom()
{
Random localRandom = new Random();
String str1 = "";
for (int i = 0; i < randomLeng; i++)
{
String str2 = String.valueOf(localRandom.nextInt(10));
str1 = str1 + str2;
}
return str1;
}
public static String genOrderNo()
{
long l = genId();
String str = dateFormat.format(new Date());
return str + l;
}
public static void main(String[] paramArrayOfString)
throws Exception
{}
}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
java大話之創(chuàng)建型設(shè)計模式教程示例
這篇文章主要為大家介紹了java大話之創(chuàng)建型設(shè)計模式教程示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02
SpringBoot+Vue實現(xiàn)數(shù)據(jù)添加功能
這篇文章主要介紹了SpringBoot+Vue實現(xiàn)數(shù)據(jù)添加功能,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03
排查Failed?to?validate?connection?com.mysql.cj.jdbc.Connec
這篇文章主要介紹了Failed?to?validate?connection?com.mysql.cj.jdbc.ConnectionImpl問題排查,具有很好的參考價值,希望對大家有所幫助2023-02-02
一文探究ArrayBlockQueue函數(shù)及應(yīng)用場景
這篇文章主要為大家介紹了一文探究ArrayBlockQueue函數(shù)及應(yīng)用場景,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-03-03

