Mybatis动态插入数据(使用trim标签)

Mybatis动态插入数据(使用trim标签)

有时我们控制同一张表,但传入的参数不固定,操作表的字段不固定,就要用到mybatis动态插入。.xml如下:

<insert id="insertMessage" parameterType="com.sf.ccsp.member.client.request.MessageReq">
       insert cx_customer_message
       (ID,MEMBERID,
         <if test='messageClassify != null and messageClassify != "" '>
             MESSAGEE_CLASSIFY,
         </if>
         <if test='messageCode != null and messageCode != "" '>
             MESSAGE_CODE,
         </if>
         <if test='messageContent != null and messageContent != "" '>
             MESSAGE_CONTENT
         </if>
        )
       values (
         #{id, jdbcType=VARCHAR},
         #{memberId, jdbcType=VARCHAR},
          <if test='messageClassify != null and messageClassify != "" '>
            #{messageClassify, jdbcType=VARCHAR},
          </if>
          <if test='messageCode != null and messageCode != "" '>
            #{messageCode, jdbcType=VARCHAR},
          </if>
          <if test='messageContent != null and messageContent != "" '>
            #{messageContent, jdbcType=VARCHAR}
          </if>
        )
</insert>

问题来了,当messageClassify !=null,但messageCode 和messageContent 为空时,会多出来逗号,以至于mybatis报错。正确的用法如下.xml:

<insert id="insertMessage" parameterType="com.sf.ccsp.member.client.request.MessageReq">
       insert cx_customer_message
        <trim prefix="(" suffix=")" suffixOverrides="," >
          ID,MEMBERID,
          <if test='messageClassify != null and messageClassify != "" '>
             MESSAGEE_CLASSIFY,
          </if>
          <if test='messageCode != null and messageCode != "" '>
             MESSAGE_CODE,
          </if>
         <if test='messageContent != null and messageContent != "" '>
             MESSAGE_CONTENT,
         </if>
        </trim>

        <trim prefix="values (" suffix=")" suffixOverrides="," >
          #{id, jdbcType=VARCHAR},
          #{memberId, jdbcType=VARCHAR},
          <if test='messageClassify != null and messageClassify != "" '>
            #{messageClassify, jdbcType=VARCHAR},
          </if>
          <if test='messageCode != null and messageCode != "" '>
            #{messageCode, jdbcType=VARCHAR},
          </if>
          <if test='messageContent != null and messageContent != "" '>
            #{messageContent, jdbcType=VARCHAR},
          </if>
        </trim>  
</insert>

trim标签的属性

  1. prefix:前缀覆盖并增加其内容。也就是给中的sql语句加上前缀;
  2. suffix:后缀覆盖并增加其内容。给包裹的sql语句加上后缀;
  3. prefixOverrides:前缀判断的条件。取消指定的前缀,如where;
  4. suffixOverrides:后缀判断的条件。取消指定的后缀,如and | or.,逗号等。

MyBatis 的 `foreach` 和 `trim` 是用于动态 SQL 的两个强大工具,它们结合使用可以简化复杂的查询构造过程,并支持高效的数据批量处理。 ### 什么是 MyBatis 的 `foreach`? `foreach` 标签允许您遍历一组数据并构建相应的 SQL 语句。这对于需要循环插入多行数据的情况非常有用,比如批量插入数据库记录。 ### 什么是 MyBatis 的 `trim`? `trim` 标签用于动态修改 SQL 语句的不同部分,包括添加前缀、后缀以及清除不需要的部分。这使得编写动态 SQL 变得更为灵活和安全,避免 SQL 注入的风险。 ### `foreach` 配合 `trim` 实现批量插入的例子: 假设我们有一个实体类 `User`,包含 `id`, `name`, 和 `age` 字段,并且我们有一批这样的用户实例列表,希望通过 MyBatis 批量插入数据库中。以下是具体的配置示例: #### XML 映射文件 (`UserMapper.xml`): ```xml <mapper namespace="com.example.mapper.UserMapper"> <insert id="batchInsertUsers" parameterType="java.util.List<com.example.entity.User>" resultType="void"> INSERT INTO users (name, age) SELECT #{users[i].name}, #{users[i].age} FROM dual WHERE EXISTS ( <foreach item="item" index="index" collection="users" open="(" separator="," close=")" > #{item.name} as name, #{item.age} as age, IFNULL(NULLIF(#{item.id},''), uuid()) as id </foreach> ) </insert> </mapper> ``` 在这个例子中,`foreach` 用于遍历传入的 `List<User>`,并为每个元素生成对应的 SQL 行。这里同时使用了 `trim` 来确保生成的 SQL 包含必要的表名、列名等,并通过 `open`, `separator`, 和 `close` 属性自定义字符串拼接规则。 ### 使用场景 1. **批量操作**:当需要将大量相似数据一次性插入数据库时,使用 `foreach` 和 `trim` 可以避免重复书写 SQL 语句,提高代码可读性和维护性。 2. **复杂条件下的插入**:如果批量插入需要满足特定条件(如唯一约束、默认值等),动态 SQL 的灵活性可以帮助构造正确的 SQL 语句。 3. **优化性能**:对于大数据量的操作,合理利用 MyBatis动态 SQL 功能,可以在不牺牲性能的情况下保证程序的健壮性和可扩展性。 ###
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值