myBaits 拼接sql语句进行批量执行sql语句插入

##最重要的一点!!!!

在配置文件中必须添加“&allowMultiQueries=true”

spring:
  datasource:
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://********:3306/tollstationweightdetection?useSSL=false&useUnicode=true&characterEncoding=utf8&serverTimezone=GMT%2B8&allowMultiQueries=true
    username: root
    password: ********

service层:

@Autowired
ParameterVersionMapper parameterVersionMapper;
@Override
public int insertPermissionVersionInfo(String permissionDownloadRes) {
    //批量插入,sql语句进行拼接
    StringBuffer sqlStrBuffer = new StringBuffer();
    StringBuffer valueStrBuffer = new StringBuffer();
    ArrayList<String> sqlList = new ArrayList<>();
    String insert = "INSERT INTO tb_permissionall (";
    String value = "values (";
    for (String res : permissionDownloadRes.split("\n")) {
        sqlStrBuffer.append(insert);
        valueStrBuffer.append(value);
        if (!"".equals(res.split("#")[0]) && res.split("#")[0] != null) {
            sqlStrBuffer.append("cert_no,");
            valueStrBuffer.append("'").append(res.split("#")[0]).append("',");
        }
        if (!"".equals(res.split("#")[1]) && res.split("#")[1] != null) {
            sqlStrBuffer.append("provinces,");
            valueStrBuffer.append("'").append(res.split("#")[1]).append("',");
        }
        sqlStrBuffer.deleteCharAt(sqlStrBuffer.length() - 1);
        valueStrBuffer.deleteCharAt(valueStrBuffer.length() - 1);
        sqlStrBuffer.append(") ").append(valueStrBuffer).append(")");
        valueStrBuffer.setLength(0);
        sqlList.add(sqlStrBuffer.toString());
        sqlStrBuffer.setLength(0);
    }
   return parameterVersionMapper.insertPermissionVersionInfo(sqlList);
}

**mapper.xml

<update id="insertPermissionVersionInfo" parameterType="java.util.List">
    <foreach collection="sqlList" item="item" separator=";">
        ${item}
    </foreach>
</update>

  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值