自定义Java类实现ID自增,无需数据库主键

5星 · 超过95%的资源 需积分: 48 201 下载量 31 浏览量 更新于2024-09-13 2 收藏 1KB TXT 举报
在Java编程中,有时候我们需要在不依赖数据库主键自增机制的情况下,实现一个自定义的ID生成策略。这篇文章介绍了一种基于Java的方法,用于生成特定表名的唯一ID,即ID自增。方法名为`findId`,接收一个参数`table_name`,表示需要生成ID的表名。 首先,该方法通过`DbPoolManager`获取数据库连接(Connection)。接着,创建一个Statement对象来执行SQL查询,其目的是获取当前表中ID列的最大值。SQL语句使用了变量`id`(格式为`table_name_id`),并使用`substring`方法提取表名的前两个字符作为前缀(如"table_name_00")。 如果查询结果中存在最大ID,程序会将其转换为整数并加1。例如,如果最大ID是"00000123",则新ID将变为"00000124"。这里使用了`substring`和`Integer.parseInt`来处理字符串形式的数字。如果找不到最大ID,初始值设置为"00000001"。 异常处理部分,代码捕获了可能抛出的SQLException,并打印错误信息,确保了在出现数据库连接或操作问题时能优雅地处理。最后,关闭ResultSet、Statement和Connection对象以释放资源,并返回生成的新ID。 这种方法适合于那些需要自定义ID生成规则,且不想频繁依赖数据库的场景,例如开发简单的应用或者进行测试时。然而,这种方式并不适用于大规模生产环境,因为可能存在并发控制和性能瓶颈,对于这类需求,数据库自身的序列化ID生成机制更为高效和可靠。在实际项目中,通常会选择数据库级别的解决方案,如MySQL的`AUTO_INCREMENT`属性或Oracle的序列功能。
2018-11-02 上传
public synchronized String nextId() { long timestamp = timeGen(); //获取当前毫秒数 //如果服务器时间有问题(时钟后退) 报错。 if (timestamp < lastTimestamp) { throw new RuntimeException(String.format( "Clock moved backwards. Refusing to generate id for %d milliseconds", lastTimestamp - timestamp)); } //如果上次生成时间和当前时间相同,在同一毫秒内 if (lastTimestamp == timestamp) { //sequence自增,因为sequence只有12bit,所以和sequenceMask相与一下,去掉高位 sequence = (sequence + 1) & sequenceMask; //判断是否溢出,也就是每毫秒内超过4095,当为4096时,与sequenceMask相与,sequence就等于0 if (sequence == 0) { timestamp = tilNextMillis(lastTimestamp); //自旋等待到下一毫秒 } } else { sequence = 0L; //如果和上次生成时间不同,重置sequence,就是下一毫秒开始,sequence计数重新从0开始累加 } lastTimestamp = timestamp; long suffix = (datacenterId << datacenterIdShift) | (workerId << workerIdShift) | sequence; String datePrefix = DateFormatUtils.format(timestamp, "yyyyMMddHHMMssSSS"); return datePrefix + suffix; } protected long tilNextMillis(long lastTimestamp) { long timestamp = timeGen(); while (timestamp <= lastTimestamp) { timestamp = timeGen(); } return timestamp; } protected long timeGen() { return System.currentTimeMillis(); } private byte getLastIP(){ byte lastip = 0; try{ InetAddress ip = InetAddress.getLocalHost(); byte[] ipByte = ip.getAddress(); lastip = ipByte[ipByte.length - 1]; } catch (UnknownHostException e) { e.printStackTrace(); } return lastip; }