mybatis之<trim prefix="" suffix="" suffixOverrides="" prefixOverride

xiaoxiao2021-02-28  37

1.<trim prefix="" suffix="" suffixOverrides="" prefixOverrides=""></trim> prefix:在trim标签内sql语句加上前缀。 suffix: 在trim标签内sql语句加上后缀。 suffixOverrides:指定去除多余的后缀内容,如:suffixOverrides=",",去除trim标签内sql语句多余的后缀","。 prefixOverrides: 指定去除多余的前缀内容 2.下面是一个往购物车表中插入数据的mybatis语句 [java]  view plain  copy <insert id="insert" parameterType="com.tortuousroad.groupon.cart.entity.Cart">          insert into cart          <trim prefix="(" suffix=")" suffixOverrides=",">              <if test="id != null">                  id,              </if>              <if test="userId != null">                  user_id,              </if>              <if test="dealId != null">                  deal_id,              </if>              <if test="dealSkuId != null">                  deal_sku_id,              </if>              <if test="count != null">                  count,              </if>              <if test="createTime != null">                  create_time,              </if>              <if test="updateTime != null">                  update_time,              </if>          </trim>          <trim prefix="values (" suffix=")" suffixOverrides=",">              <if test="id != null">                  #{id,jdbcType=BIGINT},              </if>              <if test="userId != null">                  #{userId,jdbcType=BIGINT},              </if>              <if test="dealId != null">                  #{dealId,jdbcType=BIGINT},              </if>              <if test="dealSkuId != null">                  #{dealSkuId,jdbcType=BIGINT},              </if>              <if test="count != null">                  #{count,jdbcType=INTEGER},              </if>              <if test="createTime != null">                  #{createTime,jdbcType=TIMESTAMP},              </if>              <if test="updateTime != null">                  #{updateTime,jdbcType=TIMESTAMP},              </if>          </trim>      </insert>   假设没有指定 [java]  view plain  copy suffixOverrides=","   执行的sql语句也许是这样的:insert into cart (id,user_id,deal_id,) values(1,2,1,);显然是错误的 指定之后语句就会变成 insert into cart (id,user_id,deal_id) values(1,2,1);这样就将“,”去掉了。 前缀也是一个道理这里就不说了。
转载请注明原文地址: https://www.6miu.com/read-2625543.html

最新回复(0)