mybaits insert动态添加<trim>以及添加返回自增长编号

  1. 起因:需要返回insert的 生成的主键,动态添加
  2. 参考: 
    标题网址

    Mybatis 动态insert语句

    https://blog.csdn.net/qq_35661171/article/details/82260708

    Mybatis中,当插入数据后,返回最新主键id的几种方法,及具体用法

    https://blog.csdn.net/yueloveme/article/details/78483072
  3. 代码:

    Controller和Mybatis xml代码
        @RequestMapping(value = "/save", method = {RequestMethod.POST, RequestMethod.GET})
        @RequiresPermissions("app:notice:save")
        @ApiOperation("保存")
        public R save(@RequestBody @ApiParam(name = "对象", value = "传入json格式", required = 
         true) NoticeEntity notice) {
            /***
             *  需求:
             *      保存一个,添加进去关系表中,循环    添加
             */
            notice.setCreatetime(new Date());
            notice.setModifytime(new Date());
            noticeService.insertOrID(notice);
            //注意返回主键ID是返回到你的实体类中的,直接取值就可以了 
            if (notice.getId() == null || notice.getId() == 0) {
                return R.error("添加错误");
            }
        }
       <!-- 动态添加并返回生成的编号 -->
        <insert id="insertOrID" parameterType="io.huban.modules.app.entity.NoticeEntity" 
         useGeneratedKeys="true" keyProperty="id">
            insert into tb_notice
             <trim prefix="(" suffix=")" suffixOverrides=",">
                <if test="id != null">id,</if>
                <if test="content != null">content,</if>
                <if test="status != null">status,</if>
                <if test="createtime != null">createtime,</if>
                <if test="modifytime != null">modifytime</if>
             </trim>
            <trim prefix="values (" suffix=")" suffixOverrides=",">
                <if test="id != null">#{id},</if>
                <if test="content  != null">#{content},</if>
                <if test="status  != null">#{status},</if>
                <if test="createtime  != null">#{createtime},</if>
                <if test="modifytime  != null">#{modifytime}</if>
            </trim>
        </insert>

    具体的参数如下:

    参数名解释
    useGeneratedKeys默认值unset,用于设置getGeneratedKeys方法或selectKey子元素返回值将赋值到领域模型的哪个属性中
    keyProperty取值范围true|false(默认值),设置是否使用JDBC的getGenereatedKeys方法获取主键并赋值到keyProperty设置的领域模型属性中。MySQL和SQLServer执行auto-generated key field,因此当数据库设置好自增长主键后,可通过JDBC的getGeneratedKeys方法获取。但像Oralce等不支持auto-generated key field的数据库就不能用这种方法获取主键了
    trim mybatis中的循环语句定义了prefix:前缀,suffix:后缀,还有suffixOverrides:间隔中应添加的

     

     

 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值