码迷,mamicode.com
首页 > 其他好文 > 详细

JPA的坑多服务主键重复

时间:2017-03-17 18:47:27      阅读:514      评论:0      收藏:0      [点我收藏+]

标签:hiberna   插入数据   虚拟机   div   文档   群集   ted   ssi   gen   

配置如下

 @Id
    @GeneratedValue(generator="generator")
	@GenericGenerator(name="generator",strategy="increment")
    @Column(name = "id")
    public Long getId() {
		return id;
	}

 问题就 出在这

由Hibernate从数据库中取出主键的最大值(每个session只取1次),以该值为基础,每次增量为1,在内存中生成主键,不依赖于底层的数据库,因此可以跨数据库。

<id name="id" column="id">

<generator class="increment" />

</id>

Hibernate调用org.hibernate.id.IncrementGenerator类里面的generate()方法,使用select max(idColumnName) from tableName语句获取主键最大值。该方法被声明成了synchronized,所以在一个独立的Java虚拟机内部是没有问题的,然而,在多个JVM同时并发访问数据库select max时就可能取出相同的值,再insert就会发生Dumplicate entry的错误。所以只能有一个Hibernate应用进程访问数据库,否则就可能产生主键冲突,所以不适合多进程并发更新数据库,适合单一进程访问数据库,不能用于群集环境。

官方文档:只有在没有其他进程往同一张表中插入数据时才能使用,在集群下不要使用。

特点:跨数据库,不适合多进程并发更新数据库,适合单一进程访问数据库,不能用于群集环境。

JPA的坑多服务主键重复

标签:hiberna   插入数据   虚拟机   div   文档   群集   ted   ssi   gen   

原文地址:http://www.cnblogs.com/JAYIT/p/6567591.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!