SchedulePstThread.java
3.34 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
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);
}
}
}