Mybatis中insert方法返回 新增主键id

1.controller里面构建实体,去数据库新增记录

        advert.setStatus(1);
        ........            //给实体advert中的各个字段赋值
        int result = advertService.createdAdvert(advert);        
        if(result==1){            
        //下面这个方法用到被创建的实体advert          
        ScheduleJob jobStart = scheduleJobManager.creatScheduleAdStart(advert);

如果creatScheduleAdStart方法用到advert数据库表中创建后自增的id,这里是不会取到的

2.修改Mapping

    <insert id="created" parameterType="Advert" keyProperty="id" useGeneratedKeys="true">
        INSERT INTO
        <include refid="tb" />
        (
        <include refid="cols_exclude_id" />
        )
        VALUES
        (
        <include refid="vals" />
        )
    </insert>

在mapping中,对id="created"的insert加上keyProperty="id" useGeneratedKeys="true" 这两个参数,就可以让

int result = advertService.createdAdvert(advert);

调用这个方法的同时,更新实体advert,让advert获得表记录新增后自增的id

注意:这种方法传入的类型,也就是parameterType要是Map或者是对应的类


转载于:https://my.oschina.net/gxiao/blog/550498

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值