【踩坑】联合主键情况下,JPA非主键设置自动增长无效

1.问题

  • order_info表里面,采用product_id,order_id作为联合主键,还有一个属性id,想设置成自增长的非主键。如果在建表时sql语句里加上 key(id)就可以解决。
  • 但是,开发阶段,使用spring.jpa.hibernate.ddl-auto=create 根据entity自动生成mysql表,发现下面的配置无效,生成的表id 是没有auto_increment关键字的。
@IdClass(CommonPk.class)
public class OrderInfo{
    @Id 
    @GeneratedValue(strategy= GenerationType.IDENTITY) 
    @Column(name = "id") 
    private Long id;

    
    private String productId;

    private String orderId;

}

//其中,
class CommonPk implements Serializable{
    private String productId;

    private String orderId;

}

2.解决方法

  • 也许不是最优解,但网上搜了一圈也没有个解决方案,也许是没找对地方,但自己想出了一个解决办法
  • 如下,@Column加个columnDefinition属性 @Column(name = "id", columnDefinition = "bigint(20) not null UNIQUE key auto_increment")

转载于:https://my.oschina.net/eqshen/blog/3033869

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值