mysql 报Error 1390: Prepared statement contains too many placeholdersy - 记一次xorm插入多条数据得报错

近日使用xorm插入多条数据时发现出错Error 1390: Prepared statement contains too many placeholders

网上发现是占位符过多,原来是xorm生成了多条insertsql一起执行报的错,一条sql占位符不能超过65535个

我使用得解决办法是分批次插入

//插入前判断是否大于2000条,如果大于2000就分批
func preInsert(acc []int) error {
	index := 0
	//如果不超过两千条即直接插入即可
	if len(acc) < 2000 { //这里分为两千条插入一次
		//直接插入	//todo 
		fmt.Println(acc) //这里改为插入函数
		return nil
	}
	//分批插入
	for index < len(acc) {
		if index+2000 > len(acc) { 
			fmt.Println("插入区间",index,len(acc))
				//todo 
			fmt.Println( acc[index:]) //这里改为插入函数
			index = len(acc)
			break
		} else {
			fmt.Println("插入区间",index,index+2000)
			//todo 
			fmt.Println(  acc[index:index+2000]) //这里改为插入函数
			index += 2000
		}
	}
	return nil
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值