Java实现自动生成数据库主键ID(java生成数据库主键id)

在数据库设计中,主键是被用来唯一标识一条记录的一个或一组字段,是保证数据完整性的一个重要组成部分。而生成主键ID就是为了防止数据重复而设定一个唯一的标识符,并且它的格式一般都是整数或字符型。然而,在很多情况下,数据库的主键ID需要手动输入或手动生成,这对系统的开发和部署带来了一定的麻烦。本文将介绍如何利用的方法,帮助开发者更轻松地完成这一步骤。

目前成都创新互联已为1000多家的企业提供了网站建设、域名、网络空间、网站改版维护、企业网站设计、梓潼网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。

方法一、使用UUID生成主键ID

方法一:使用UUID

UUID是一种通用唯一识别码的缩写,作为标准的制定者是微软公司,但它在开源领域得到了广泛应用。其优点在于它可以生成一个唯一的ID,而且可以在一定程度上防止数据碰撞。因此,在Java中很多ORM框架和数据库工具库都有uuid的封装,比如Hibernate、Mybatis等等。

Java代码示例:

“` java

import java.util.UUID;

public class PrimaryKeyUtil {

public static String getUUID() {

UUID uuid = UUID.randomUUID();

String str = uuid.toString();

// 去掉”-“符号

return str.replaceAll(“-“, “”);

}

}

“`

方法二、使用SnowFlake生成主键ID

方法二:使用SnowFlake算法

SnowFlake算法是Twitter官方开源的分布式ID生成算法,其核心思想是将一个64位的整数分配给每个机器,然后再将这个64位的整数分成三个部分:41位作为时间戳,10位作为机器ID,12位作为序列号,这样可以保证在同一机器上同时生成主键时不会冲突。SnowFlake算法的优点在于其规律性和唯一性,在分布式场景下也有着很好的性能表现。

Java代码示例:

“` java

public class PrimaryKeyUtil {

/**

* 起始的时间戳

*/

private final static long START_TIMESTAMP = 1480166465631L;

/**

* 每一部分占用的位数

*/

private final static long SEQUENCE_BIT = 12;

private final static long MACHINE_BIT = 5;

private final static long DATACENTER_BIT = 5;

/**

* 每一部分的更大值

*/

private final static long MAX_DATACENTER_NUM = ~(-1L

private final static long MAX_MACHINE_NUM = ~(-1L

private final static long MAX_SEQUENCE = ~(-1L

/**

* 每一部分向左的位移

*/

private final static long MACHINE_LEFT = SEQUENCE_BIT;

private final static long DATACENTER_LEFT = SEQUENCE_BIT + MACHINE_BIT;

private final static long TIMESTAMP_LEFT = DATACENTER_LEFT + DATACENTER_BIT;

private static long datacenterId = 1L; // 数据中心

private static long machineId = 1L; // 机器标识

private static long sequence = 0L; // 序列号

private static long lastTimeStamp = -1L;// 上一次时间戳

/**

* 生成下一个ID

*

* @return String类型的ID

*/

public synchronized static String nextId() {

long currTimeStamp = getNewTimeStamp();

if (currTimeStamp

throw new RuntimeException(“Clock moved backwards. Refusing to generate id”);

}

if (currTimeStamp == lastTimeStamp) {

sequence = (sequence + 1) & MAX_SEQUENCE;

if (sequence == 0L) {

currTimeStamp = getNextTimeStamp();

}

} else {

sequence = 0L;

}

lastTimeStamp = currTimeStamp;

return (currTimeStamp – START_TIMESTAMP)

| datacenterId

| machineId

| sequence;

}

private static long getNextTimeStamp() {

long timeStamp = getNewTimeStamp();

while (timeStamp

timeStamp = getNewTimeStamp();

}

return timeStamp;

}

private static long getNewTimeStamp() {

return System.currentTimeMillis();

}

}

“`

在实现自动生成数据库主键ID时,应根据需求进行选择。使用UUID可以简单实现自动生成主键ID,并且具有很高的唯一性,但是其序列号可能过于随机,不适合需要排序的数据,而使用SnowFlake算法生成主键ID则可以保证顺序,并且具有良好的唯一性,适合多用户、大数据量的高可用性场景。

相关问题拓展阅读:

  • Java主键序列生成,需求如下.
  • java程序往mysql数据库中插入数据,主键ID是varchar型的,是数字

Java主键序列生成,需求如下.

思路:

序列生成方法入参必须有上级菜单序列、菜单级别陵铅;如尺耐好果是一级菜单上级菜单序列为空

引入数据库或者文件保存已生成的菜单,两个方法,一个读,一个写,注意并发操作(加同步锁)

每次调用序列生成方法时根据上级菜单序列创建其他菜单,,如果上级菜单序列为空时读取文件取更大上级菜单序列再加1,否则直接递增子菜单再写入文亩肆件

需求都这么明确了,自己组主键呗

java程序往mysql数据库中插入数据,主键ID是varchar型的,是数字

因为你的eid是varchar类型的,所以在排序的时候 10是等于壹零 而不是十,所以就会出现1后面排序10的情况了,除非你在查询的时候把eid转成integer,然后再按照integer的排序,就可以实现顺序排列了.

关于java生成数据库主键id的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。

香港服务器选创新互联,2H2G首月10元开通。
创新互联(www.cdcxhl.com)互联网服务提供商,拥有超过10年的服务器租用、服务器托管、云服务器、虚拟主机、网站系统开发经验。专业提供云主机、虚拟主机、域名注册、VPS主机、云服务器、香港云服务器、免备案服务器等。

网站名称:Java实现自动生成数据库主键ID(java生成数据库主键id)
标题链接:http://www.csdahua.cn/qtweb/news36/267736.html

网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网