ORCL 使用MyBatis批量添加

ORCL 使用MyBatis批量添加

Service代码

 	/**
     * 同步历史会议数据
     * 作者: 吴 波
     * 时间: 2020-03-11 15:36
     * 笔名: 那年秋天的茄子^^
     */
    private void syncMeetHistorys(Date startTime, Date endTime) {
        Result<JSONArray> history         = HistroryApi.getHistory(startTime, endTime);
        JSONArray         historyData     = history.getData();
        List<MeetHistory> meetHistoryList = new ArrayList<>(historyData.size());
        historyData.stream().forEach(jsonobejct -> {
            JSONObject  mettHistoryJsonObject = (JSONObject) jsonobejct;
            MeetHistory meetHistory           = JSONObject.toJavaObject(mettHistoryJsonObject, MeetHistory.class);
            meetHistoryList.add(meetHistory);
        });

        if (meetHistoryList.size() != 0) {
            this.meetHistoryMapper.insertMeetHistoryList(meetHistoryList);
        }

        Result<JSONArray>     historyInfo         = HistroryApi.getHistoryInfo(startTime, endTime);
        JSONArray             historyInfoData     = historyInfo.getData();
        List<MeetHistoryInfo> meetHistoryInfoList = new ArrayList<>(historyInfoData.size());
        historyInfoData.stream().forEach(jsonobejct -> {
            JSONObject      mettHistoryInfoJsonObject = (JSONObject) jsonobejct;
            MeetHistoryInfo meetHistoryInfo           = JSONObject.toJavaObject(mettHistoryInfoJsonObject, MeetHistoryInfo.class);
            log.info("数据为\n{}", meetHistoryInfo);
            meetHistoryInfoList.add(meetHistoryInfo);
        });

        if (meetHistoryInfoList.size() != 0) {
            this.meetHistoryInfoMapper.insertMeetHistoryList(meetHistoryInfoList);
        }

    }

Mapper 代码

package com.itechhero.app.module.edu.meet.history.mapper;

import com.itechhero.app.module.edu.BaseMapper;
import com.itechhero.app.module.edu.meet.history.model.MeetHistoryInfo;
import org.apache.ibatis.annotations.Param;

import java.util.List;

public interface MeetHistoryInfoMapper extends BaseMapper<MeetHistoryInfo> {
    /**
     * 批量添加数据
     * 作者: 吴 波
     * 时间: 2020-03-12 9:44
     * 笔名: 那年秋天的茄子^^
     */
    void insertMeetHistoryList(@Param("meetHistoryInfos") List<MeetHistoryInfo> meetHistoryInfos);
}

Mapper.xml文件

 <insert id="insertMeetHistoryList" parameterType="java.util.List" useGeneratedKeys="false">
        INSERT INTO YJ_MEET_HISTORY_INFO(ID, PARTICIPANT_ID, PARTICIPANT_DEVICE_TYPE, JOIN_TIME_BEGIN,
        JOIN_TIME_END, DURATION, MEETING_NUMBER, MEETING_NAME, DISPLAY_NAME, MEETING_ID)

        SELECT SYS_GUID(),s.* FROM
        <foreach collection="meetHistoryInfos" open="(" separator="UNION ALL" close=") s" item="item">
            SELECT
            #{item.participantId},
            #{item.participantDeviceType},
            #{item.joinTimeBegin},
            #{item.joinTimeEnd},
            #{item.duration},
            <if test="item.meetingNumber==null">
                null,
            </if>
            <if test="item.meetingNumber!=null">
                #{item.meetingNumber},
            </if>
            <if test="item.meetingNumber==null">
                null,
            </if>
            <if test="item.meetingNumber!=null">
                #{item.meetingName},
            </if>
            #{item.displayName},
            #{item.meetingId}
            FROM DUAL
        </foreach>
    </insert>
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值