批量插入sql语句:
INSERT INTO table (field1,field2,field3) VALUES ('a',"b","c"), ('a',"b","c"),('a',"b","c")
mybatis通过foreach循环拼装了如上的sql语句。
一、xml
1 <?xml version="1.0" encoding="UTF-8" ?> 2 <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" > 3 <mapper 4 namespace="com.xxx.mapper.XXXRecordMapper"> 5 <resultMap id="BaseResultMap" type="com.xxx.model.XXXRecord"> 6 <id column="AutoId" property="autoid" jdbcType="BIGINT" /> 7 <result column="UserId" property="userid" jdbcType="BIGINT" /> 8 <result column="NoticedTime" property="noticedtime" jdbcType="TIMESTAMP" /> 9 </resultMap> 10 <sql id="Base_Column_List"> 11 AutoId, UserId, NoticedTime 12 </sql> 13 <!-- myself:批量插入 --> 14 <insert id="insertBatch" parameterType="java.util.List"> 15 insert into T_XXXRecord (AutoId, UserId, NoticedTime) values 16 <foreach collection="list" item="item" index="index" separator=","> 17 (#{item.autoid,jdbcType=BIGINT}, 18 #{item.userid,jdbcType=BIGINT}, 19 #{item.noticedtime,jdbcType=TIMESTAMP}) 20 </foreach> 21 </insert> 22 </mapper>
说明:
- mysql批量插入的限制是一次批量:1M
- 我这里插入的List,如上就好,如果是其他结构,查看这篇博客:http://www.cnblogs.com/admol/articles/4248159.html
- collection属性:
1.如果传入的是单参数且参数类型是一个List的时候,collection属性值为list
2.如果传入的是单参数且参数类型是一个array数组的时候,collection的属性值为array
3.如果传入的参数是多个的时候,我们就需要把它们封装成一个Map了,当然单参数也可以封装成map
分类:
Mybatis相关
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 一文读懂知识蒸馏
· 终于写完轮子一部分:tcp代理 了,记录一下