SchedulePstThread.java 3.34 KB
package com.bsth.data.schedule.thread;

import com.alibaba.fastjson.JSON;
import com.bsth.data.schedule.DayOfSchedule;
import com.bsth.entity.realcontrol.ScheduleRealInfo;
import com.bsth.repository.realcontrol.ScheduleRealInfoRepository;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.namedparam.BeanPropertySqlParameterSource;
import org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate;
import org.springframework.stereotype.Component;

/**
 * @author PanZhao
 * @ClassName: SchedulePstThread
 * @Description: TODO(班次异步持久化)
 * @date 2016年8月24日 上午1:47:05
 */
@Component
public class SchedulePstThread extends Thread {

    @Autowired
    ScheduleRealInfoRepository scheduleRepository;

    @Autowired
    NamedParameterJdbcTemplate jdbcTemplate;

    @Autowired
    DayOfSchedule dayOfSchedule;

    Logger logger = LoggerFactory.getLogger(this.getClass());

    @Override
    public void run() {

        ScheduleRealInfo schedule;
        for (int i = 0; i < 1000; i++) {
            schedule = DayOfSchedule.pstBuffer.poll();
            if (null == schedule)
                break;

            if (schedule.isDeleted()) {
                logger.error("save 发现 deleted=true 的班次,id: " + schedule.getId());
                continue;
            }

            save(schedule);
        }
    }

    /**
     * 班次更新到数据库,不走jpa
     *
     * @param sch
     */
    public void save(ScheduleRealInfo sch) {
        if (sch.getId() == null) {
            logger.error("入库的班次没有ID, " + JSON.toJSONString(sch));
            return;
        }

        if(sch.getSaveFailCount() > 5){
            logger.error("入库失败上限, " + JSON.toJSONString(sch));
            return;
        }

        try {
            String sql = "UPDATE bsth_c_s_sp_info_real" +
                    " SET adjust_exps=:adjustExps, bc_type=:bcType, bcs=:bcs, bcsj=:bcsj, ccno=:ccno, cl_zbh=:clZbh, df_auto=:dfAuto," +
                    " dfsj=:dfsj, directive_state=:directiveState, fcno=:fcno, fcsj=:fcsj, fcsj_actual=:fcsjActual, fgs_bm=:fgsBm, fgs_name=:fgsName, gs_bm=:gsBm, gs_name=:gsName," +
                    " j_gh=:jGh, j_name=:jName, jhlc=:jhlc, jhlc_orig=:jhlcOrig, lp_name=:lpName, ONLINE=:online, qdz_code=:qdzCode, qdz_name=:qdzName," +
                    " real_exec_date=:realExecDate, reissue=:reissue, remarks=:remarks, s_gh=:sGh, s_name=:sName, schedule_date=:scheduleDate," +
                    " schedule_date_str=:scheduleDateStr, sflj=:sflj, sp_id=:spId, STATUS=:status, update_date=:updateDate, xl_bm=:xlBm, xl_dir=:xlDir, xl_name=:xlName," +
                    " zdsj=:zdsj, zdsj_actual=:zdsjActual, zdz_code=:zdzCode, zdz_name=:zdzName" +
                    " WHERE " +
                    " id=:id";

            jdbcTemplate.update(sql, new BeanPropertySqlParameterSource(sch));
            sch.setSaveFailCount(0);
        } catch (Exception e) {
            //下次入库再试
            sch.setSaveFailCount(sch.getSaveFailCount()+1);
            dayOfSchedule.save(sch);

            logger.error("班次 " + sch.getId() + "入库失败," + JSON.toJSONString(sch));
            logger.error("", e);
        }
    }
}