mybatics之<trim prefix="" suffix="" suffixOverrides="" prefixOverrides=""></trim>

本文详细介绍了 MyBatis 中 trim 标签的使用方法及其如何避免 SQL 语句中出现多余的前后缀,通过具体示例展示了如何正确地在插入数据时构造 SQL 语句。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.<trim prefix="" suffix="" suffixOverrides="" prefixOverrides=""></trim>

prefix:在trim标签内sql语句加上前缀。

suffix:在trim标签内sql语句加上后缀。

suffixOverrides:指定去除多余的后缀内容,如:suffixOverrides=",",去除trim标签内sql语句多余的后缀","。

prefixOverrides:指定去除多余的前缀内容

2.下面是一个往购物车表中插入数据的mybatis语句

<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>

假设没有指定

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);这样就将“,”去掉了。

前缀也是一个道理这里就不说了。
 

<insert id="insertMlbSmtPickQpl" parameterType="MlbSmtPickQpl" useGeneratedKeys="true" keyProperty="id"> insert into mlb_smt_pick_qpl <trim prefix="(" suffix=")" suffixOverrides=","> <if test="model != null">model,</if> <if test="site != null">site,</if> <if test="process != null">process,</if> <if test="lineName != null">line_name,</if> <if test="produceStationName != null">produce_station_name,</if> <if test="stationType != null">station_type,</if> <if test="equipmentType != null">equipment_type,</if> <if test="equipmentManu != null">equipment_manu,</if> <if test="equipmentModel != null">equipment_model,</if> <if test="ct != null">ct,</if> <if test="pickQpl != null">pick_qpl,</if> <if test="createTime != null">create_time,</if> <if test="createBy != null">create_by,</if> <if test="updateTime != null">update_time,</if> <if test="updateBy != null">update_by,</if> <if test="productType != null">product_type,</if> <if test="parentTaskNo != null">parent_task_no,</if> <if test="childTaskNo != null">child_task_no,</if> <if test="version != null">version,</if> <if test="actId != null">act_id,</if> </trim> <trim prefix="values (" suffix=")" suffixOverrides=","> <if test="model != null">#{model},</if> <if test="site != null">#{site},</if> <if test="process != null">#{process},</if> <if test="lineName != null">#{lineName},</if> <if test="produceStationName != null">#{produceStationName},</if> <if test="stationType != null">#{stationType},</if> <if test="equipmentType != null">#{equipmentType},</if> <if test="equipmentManu != null">#{equipmentManu},</if> <if test="equipmentModel != null">#{equipmentModel},</if> <if test="ct != null">#{ct},</if> <if test="pickQpl != null">#{pickQpl},</if> <if test="createTime != null">#{createTime},</if> <if test="createBy != null">#{createBy},</if> <if test="updateTime != null">#{updateTime},</if> <if test="updateBy != null">#{updateBy},</if> <if test="productType != null">#{productType},</if> <if test="parentTaskNo != null">#{parentTaskNo},</if> <if test="childTaskNo != null">#{childTaskNo},</if> <if test="version != null">#{version},</if> <if test="actId != null">#{actId},</if> </trim> </insert>改为foreach遍历写法
07-19
评论 30
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

醒悟wjn

打赏可获取源码

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值