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

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的值.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值