mybatis之foreach批量插入网络交互分析

本文介绍了一种利用MyBatis的foreach标签进行批量数据插入的方法,并通过Wireshark抓包分析了其在网络交互上的优化效果。

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

业务代码:
IGroupMemberIndexOper oper = session.getMapper(IGroupMemberIndexOper.class);
oper.saveGroupMemberIndex(indexDOList);
mapper:
<insert id="saveGroupMemberIndex" parameterType="List" useGeneratedKeys="true" keyProperty="id">
    INSERT INTO `t_group_member_index` (gid, uid, msg_id) VALUES
    <foreach collection="list" item="item" index="index" separator=",">
        (#{item.gid}, #{item.uid}, #{item.msgId})
    </foreach>
</insert>
使用foreach来批量插入数据,使用wireshark抓包观察:

逐包分析:
304:select1

305:成功
306:SET autocommit=0

307:成功
308:select @@session.tx_read_only

309:成功
310:执行insert

从抓包可以看出,mybatis的foreach,是将sql拼接了,从而实现一次网络交互批量查询,减少了网络交互次数,从而提高性能。
311:是一个异常信息,这里不去分析了
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值