mysql批量插入

批量插入

public void addCompensateDetail(final Compensate compensate, final List<ChannelPaymentVoForsearch> channelPaymentVoList) {

        logger.info("-----------【增加赔付金明细Dao开始】------------------");

        Session currentSession = this.getSessionFactory().getCurrentSession();

        for (int i = 0; i < channelPaymentVoList.size(); i++) {

            ChannelPaymentVoForsearch channelPaymentVo = channelPaymentVoList.get(i);

            Long conId = channelPaymentVo.getConId();// 取出合同号

            Query q = currentSession.createQuery(

                    "from LoanPhaseChannel loanPhaseChannel where loanPhaseChannel.conId = :param and loanPhaseChannel.phaseCompensateStatus = :phaseCompensateStatus "); // 不重要

            q.setParameter("param", conId);

            q.setParameter("phaseCompensateStatus", 1);

            @SuppressWarnings("unchecked")

            final List<LoanPhaseChannel> loanPhaseChannelList = (List<LoanPhaseChannel>) q.list();// 查询出合同对应的待赔付还款计划数据

            long startTime = System.currentTimeMillis(); // 获取开始时间

            String sql = "INSERT INTO `ECMS_COMPENSATE_DETAIL` ( `COM_ID`, `PHASE_ID`, `SETTLE_ID`, `COM_DETAIL_VERSION`, `CREATOR`, `CREATE_TIME`, `UPDATER`, `UPDATE_TIME`) VALUES ( ?, ?, ?, ?, ?, ?, ?, ?);";

            BatchPreparedStatementSetter setter = new BatchPreparedStatementSetter() {

                @Override

                public void setValues(PreparedStatement ps, int j) throws SQLException {

                    LoanPhaseChannel loanPhaseChannel = (LoanPhaseChannel) loanPhaseChannelList.get(j);

                    ps.setLong(1, compensate.getComId());

                    ps.setLong(2, loanPhaseChannel.getPhaseId());

                    ps.setLong(3, compensate.getSettleId());

                    ps.setLong(4, Long.valueOf("1"));

                    ps.setString(5, compensate.getCreator());

                    ps.setDate(6, compensate.getCreateTime() == null ?null:new Date(compensate.getCreateTime().getTime()));

                    ps.setString(7, compensate.getUpdater());

                    ps.setDate(8, compensate.getUpdateTime() == null ?null :new Date(compensate.getUpdateTime().getTime()));

                }

                @Override

                public int getBatchSize() {

                    return loanPhaseChannelList.size();

                }

            };

            jdbcTemplate.batchUpdate(sql, setter);

            long endTime = System.currentTimeMillis(); // 获取结束时间

            System.out.println("【增加赔付金明细后台运行时间】:" + (endTime - startTime) + "ms");

        }

        logger.info("-----------【增加赔付金明细Dao结束】------------------");

    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序猿的十万个为什么

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值