MyBatis传入多种参数及MYSQL大数据写入错误

本文介绍如何通过调整MySQL配置参数max_allowed_packet来解决大数据(超过1M)插入或更新时出现的问题,并提供了一种通过XML文件使用foreach标签批量处理数据的具体实现方案。
public interface JobMapper {
	int setJobBean(@Param("list")List<JobBean> list,@Param("string")String string);
	List<JobBean> getAllJobBean(String string);
	int delJobBean(String company);
}
DAO层的参数传入
<insert id="setJobBean">
		INSERT INTO jobbean VALUES
		<foreach collection="list" index="index" item="item" open=""
			separator="," close="">
			(#{string},#{item.position},#{item.positionURL},#{item.company},#{item.companyURL},#{item.address},#{item.salary},#{item.jobdate})
		</foreach>

	</insert>

XML文件的参数用foreach 读取

mysql数据,插入或更新字段有大数据时(大于1M),会出现错误。

MySQL的一个系统参数:max_allowed_packet,其默认值为1048576(1M),
查询:show VARIABLES like '%max_allowed_packet%';
修改变量值:
SET GLOBAL max_allowed_packet=16*1024*1024
或者 set @@max_allowed_packet=5*1024*1024
MySQL安装目录下的my.ini文件中的[mysqld]段中的"max_allowed_packet = 1M",如更改为4M(如果没有这行内容,增加一行),保存,重新启动MySQL服务。现在可以load大于1M的文件了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值