欢迎光临
我们一直在努力

mybatis动态拼接怎么实现有条件的插入

本文小编为大家详细介绍“mybatis动态拼接怎么实现有条件的插入”,内容详细,步骤清晰,细节处理妥当,希望这篇“mybatis动态拼接怎么实现有条件的插入”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

动态拼接实现有条件的插入

最近在做项目的时候遇到了一个很现实的问题

那就是根据场景不同,然后实现有条件的插入,说穿了就是当这列有数据的时候进行数据的插入,没有数据的时候自动忽略这列。

其实这些在mybatis的api中有涉及到,但是之前一直没有好好看,直到最近用到了才认真的看了看这块的内容。

<!-- 新增部门人员 -->
    <insert id="addStaffForApp" parameterType="com.hivescm.org.dto.StaffForAppDto" >
        insert into base_department_staff
        <trim prefix="(" suffix=")" suffixOverrides="," >
            status,
            group_id,
            staff_code,
            realname,
            create_time,
            phone,
            is_temporary
            <if test="param.email !=null">
                email,
            </if>
            <if test="param.userId !=null">
                user_id,
            </if>
            <if test="param.sex !=null">
                sex,
            </if>
        </trim>
 
        <trim prefix="values (" suffix=")" suffixOverrides="," >
            #{param.status},
            #{param.groupId},
            #{param.staffCode},
            #{param.realname},
            #{param.phone},
            #{param.temporary}
            <if test="param.email !=null">#{param.email},
            </if>
            <if test="param.userId !=null">#{param.userId},
            </if>
            <if test="param.sex !=null">#{param.sex},
            </if>
       </trim>
    </insert>

这里头的trim相信就不用多说了,经常用来去空格。这个trim标签中有三个属性,prefix这个是表明了你要拼接sql的前缀,suffix这个则是表明了动态sql的后缀,suffixOverrides这个会帮助我去掉最后一个多出来的逗号。

mybatis插入语句

mybatis插入语句一般都是这样写 

<!– useGeneratedKeys="true"把新增加的主键赋值到自己定义的keyProperty(id)中 –>

<insert id="insert" parameterType="xxx.xxx.xxx.xxx" keyProperty="id" useGeneratedKeys="true">
  • useGeneratedKeys 取值范围true|false 默认值是:false。

  • 含义:设置是否使用JDBC的getGenereatedKeys方法获取主键并赋值到keyProperty设置的领域模型属性中。

之前一直以为useGeneratedKeys="true"是让mysql数据库主键新增,其实是,插入语句后将id赋值给实体bean,即使用insert后,使用bean.getId()可以获得值,若是false,bean.getId()=null。

不管true还是false,数据库插入的数据,都会自动生成主键(前提是设置自动增长主键)。

读到这里,这篇“mybatis动态拼接怎么实现有条件的插入”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注云搜网行业资讯频道。

赞(0)
【声明】:本博客不参与任何交易,也非中介,仅记录个人感兴趣的主机测评结果和优惠活动,内容均不作直接、间接、法定、约定的保证。访问本博客请务必遵守有关互联网的相关法律、规定与规则。一旦您访问本博客,即表示您已经知晓并接受了此声明通告。