数据库主键冲突解决

新接手的工程中,测试人员反应一个简单的保存功能,有时好用,有时就经常不成功,需要重试很多次才行。

我在仔细查看了原代码逻辑,没有发现什么问题,进行了本地测试,也没发现不成功的情况。

通过翻看正式环境的log,发现了有一些id重复的报错,原来是这个搞的。

原来的实体类的id注释是这么写的:

@GenericGenerator(name="generator", strategy="increment")
    @Id
    @GeneratedValue(generator="generator")
	@Column(name = "id", unique = true, nullable = false)
	public Long getId() {
		return this.id;
	}


这样在本地单个tomcat下是没有任何问题的,可放到生产环境的集群中问题就来了。


详细解释可以看:http://articles.e-works.net.cn/pc_server/article101508.htm

@Id
    @GeneratedValue(strategy=GenerationType.IDENTITY)
    @Column(name = "id", unique = true, nullable = false)
    public Long getId() {
        return this.id;
    }


转载于:https://my.oschina.net/jasonli0102/blog/520694

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值