数据库主键生成器java代码

简介:

package com.aspboy.base.database.util;

import java.util.HashMap;

public class KeyGenerator
{
 private static KeyGenerator keygen=new KeyGenerator();
 private static final int POOL_SIZE=20;
 private HashMap keylist=new HashMap(10);
 private KeyGenerator()
 {}
 
 public static KeyGenerator getInstance()
 {
  return keygen;
 }
 public synchronized int  getNextKey(String keyName)
 {
  KeyInfo keyinfo;
  if (keylist.containsKey(keyName))
  {
   keyinfo=(KeyInfo)keylist.get(keyName);
   System.out.println("key found");
  }
  else
  {
   keyinfo=new KeyInfo(POOL_SIZE,keyName);
   keylist.put(keyName, keyinfo);
   System.out.println("new key created");
  }
  return keyinfo.getNextKey();
 }
 

}

 

 

package com.aspboy.base.database.util;

import com.aspboy.base.database.DBBean;

public class KeyInfo
{
 private int keyMax;
 private int Keymin;
 private int nextKey;
 private int poolSize;
 private String keyName;
 //private int times ;
 
 public KeyInfo(int poolSize,String keyName)
 {
  this.poolSize=poolSize;
  this.keyName=keyName;
  loadFromDB();
  //times++;
  //System.out.println("get keyvalue from db tiems=="+times);
  
 }

 public int getKeyMax() {
  return keyMax;
 }

 public int getKeymin() {
  return Keymin;
 }
 
 private void loadFromDB()
 {
  String sql1="update tb_key set KeyValue=KeyValue+"+poolSize+" where keyName='"+keyName+"'";
  DBBean.executeSql(sql1);
  String sql2="select KeyValue from  tb_key  where keyName='"+keyName+"'";
  int keyFromDB=DBBean.getIntSingle(sql2);
  keyMax=keyFromDB;
  Keymin=keyFromDB-poolSize+1;
  nextKey=Keymin;
 }

 public int getNextKey() {
  
  if (nextKey>keyMax)
  {
   loadFromDB();
   System.out.println("get keyvalue from db");
   
  }
  return nextKey++;
 }
 
 

}

 

 

 

调用 方法: KeyGenerator.getInstance().getNextKey(keyName);

 

 

keyName 为表名称

 

 

相关数据库结构:

 

表tb_key

 

字段如下:

 

 KeyValue:pk大小

 

keyName:表名

 

 

 

 

目录
相关文章
|
7天前
|
Java 测试技术 应用服务中间件
常见 Java 代码缺陷及规避方式(下)
常见 Java 代码缺陷及规避方式(下)
27 0
|
9天前
|
Java
Java中ReentrantLock释放锁代码解析
Java中ReentrantLock释放锁代码解析
25 8
|
12天前
|
前端开发 小程序 Java
uniapp上传图片 前端以及java后端代码实现
uniapp上传图片 前端以及java后端代码实现
28 0
|
13天前
|
设计模式 存储 Java
23种设计模式,享元模式的概念优缺点以及JAVA代码举例
【4月更文挑战第6天】享元模式(Flyweight Pattern)是一种结构型设计模式,旨在通过共享技术有效地支持大量细粒度对象的重用。这个模式在处理大量对象时非常有用,特别是当这些对象中的许多实例实际上可以共享相同的状态时,从而可以减少内存占用,提高程序效率
31 4
|
13天前
|
设计模式 Java 中间件
23种设计模式,适配器模式的概念优缺点以及JAVA代码举例
【4月更文挑战第6天】适配器模式(Adapter Pattern)是一种结构型设计模式,它的主要目标是让原本由于接口不匹配而不能一起工作的类可以一起工作。适配器模式主要有两种形式:类适配器和对象适配器。类适配器模式通过继承来实现适配,而对象适配器模式则通过组合来实现
30 4
|
14天前
|
存储 缓存 算法
优化 Java 后台代码的关键要点
【4月更文挑战第5天】本文探讨了优化 Java 后台代码的关键点,包括选用合适的数据结构与算法、减少不必要的对象创建、利用 Java 8 新特性、并发与多线程处理、数据库和缓存优化、代码分析与性能调优、避免阻塞调用、JVM 调优以及精简第三方库。通过这些方法,开发者可以提高系统性能、降低资源消耗,提升用户体验并减少运营成本。
|
16天前
|
Java 开发工具 流计算
flink最新master代码编译出现Java Runtime Environment 问题
在尝试编译Flink源码时遇到Java运行时环境致命错误:EXCEPTION_ACCESS_VIOLATION。问题出现在JVM.dll+0x88212。使用的是Java 11.0.28和Java HotSpot(TM) 64-Bit Server VM。系统为Windows客户端,没有生成核心dump文件。错误日志保存在hs_err_pid39364.log和replay_pid39364.log。要解决这个问题,建议检查JDK版本兼容性,更新JDK或参照错误报告文件提交Bug至http://bugreport.java.com/bugreport/crash.jsp。
|
17天前
|
Java
使用Java代码打印log日志
使用Java代码打印log日志
73 1
|
3天前
|
SQL 缓存 Java
Java数据库连接池:优化数据库访问性能
【4月更文挑战第16天】本文探讨了Java数据库连接池的重要性和优势,它能减少延迟、提高效率并增强系统的可伸缩性和稳定性。通过选择如Apache DBCP、C3P0或HikariCP等连接池技术,并进行正确配置和集成,开发者可以优化数据库访问性能。此外,批处理、缓存、索引优化和SQL调整也是提升性能的有效手段。掌握数据库连接池的使用是优化Java企业级应用的关键。
|
7天前
|
Java
代码的魔法师:Java反射工厂模式详解
代码的魔法师:Java反射工厂模式详解
18 0