mybatis-mysql 获得自增主键 Duplicate entry '1' for key 'PRIMARY' 错误

本文介绍了一种常见的MySql主键重复错误,并详细解释了如何通过调整Java代码来解决这一问题。通过修改Goods实体类的插入逻辑,确保每个记录都有唯一的自增长ID。
部署运行你感兴趣的模型镜像
public void add(Goods goods) {
        Long goodsId = goodsMapper.insert(goods.getGoods());//获得主键
        goodsDesc.setGoodsId(goodsId);
        goodsDescMapper.insert(goodsDesc);   //主键作为desc的主键
    }
mapper.xml:
    <insert id="insert" parameterType="com.pinyougou.pojo.TbGoods" >
<selectKey resultType="java.lang.Long" order="AFTER" keyProperty="id">
    SELECT LAST_INSERT_ID() AS id
</selectKey>
insert into tb_goods (id, seller_id, goods_name, 
  default_item_id, audit_status, is_marketable, 
  brand_id, caption, category1_id, 
  category2_id, category3_id, small_pic, 
  price, type_template_id, is_enable_spec, 
        ....

报错:

Cause: com.mysql.jdbc.exceptions.jdbc4.MySQLIntegrityConstraintViolationException: Duplicate entry '1' for key 'PRIMARY'

goods 的主键是 id(bigint)自增的

将上面的java文件改为,运行正常

    public void add(Goods goods) {
             goodsMapper.insert(goods.getGoods());
            goodsDesc.setGoodsId(goods.getId());
            goodsDescMapper.insert(goodsDesc);   //主键作为desc的主键
        }

原因:理解错误,goodsMapper.insert(goods.getGoods())返回的仍然是受影响的行,但是insert运行后,goods有了主键id的值.

您可能感兴趣的与本文相关的镜像

Stable-Diffusion-3.5

Stable-Diffusion-3.5

图片生成
Stable-Diffusion

Stable Diffusion 3.5 (SD 3.5) 是由 Stability AI 推出的新一代文本到图像生成模型,相比 3.0 版本,它提升了图像质量、运行速度和硬件效率

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值