Commit 2484b165652ecc9600d941f1694314397012d664

Authored by 王通
1 parent 8d34972f

1.2023-07-31更新日志

src/main/java/com/bsth/data/LineVersionsData.java
1 -package com.bsth.data;  
2 -  
3 -import com.bsth.entity.LineVersions;  
4 -import com.bsth.service.LineVersionsService;  
5 -import com.bsth.service.StationRouteService;  
6 -import org.slf4j.Logger;  
7 -import org.slf4j.LoggerFactory;  
8 -import org.springframework.beans.factory.annotation.Autowired;  
9 -import org.springframework.core.annotation.Order;  
10 -import org.springframework.stereotype.Component;  
11 -  
12 -import java.util.HashMap;  
13 -import java.util.List;  
14 -import java.util.Map;  
15 -  
16 -/**  
17 - * @ClassName: LineVersionsData  
18 - * @Description: TODO(线路版本数据管理)  
19 - */  
20 -@Component  
21 -@Order(20)  
22 -public class LineVersionsData extends Thread {  
23 -  
24 - static Logger logger = LoggerFactory.getLogger(LineVersionsData.class);  
25 -  
26 - @Autowired  
27 - LineVersionsService lineVersionsService;  
28 -  
29 - @Autowired  
30 - StationRouteService stationRouteService;  
31 -  
32 - @Override  
33 - public void run() {  
34 - try {  
35 - List<LineVersions> list = lineVersionsService.lineUpdate();  
36 - if(list.size() == 0){  
37 - logger.info("没有需要更新的线路!");  
38 - return;  
39 - }  
40 - for (LineVersions lineVersions : list) {  
41 - Integer lineId = lineVersions.getLine().getId();  
42 - // 更新线路文件  
43 - Map<String, Object> map = new HashMap<>();  
44 - map.put("lineId", lineId);  
45 - stationRouteService.usingSingle(map);  
46 - logger.info("线路版本更新成功!");  
47 - }  
48 - } catch (Exception e) {  
49 - e.printStackTrace();  
50 - logger.error("线路版本更新出现异常!", e);  
51 - }  
52 - }  
53 -} 1 +package com.bsth.data;
  2 +
  3 +import com.bsth.entity.LineVersions;
  4 +import com.bsth.service.LineVersionsService;
  5 +import com.bsth.service.StationRouteService;
  6 +import org.slf4j.Logger;
  7 +import org.slf4j.LoggerFactory;
  8 +import org.springframework.beans.factory.annotation.Autowired;
  9 +import org.springframework.core.annotation.Order;
  10 +import org.springframework.stereotype.Component;
  11 +
  12 +import java.util.HashMap;
  13 +import java.util.List;
  14 +import java.util.Map;
  15 +
  16 +/**
  17 + * @ClassName: LineVersionsData
  18 + * @Description: TODO(线路版本数据管理)
  19 + */
  20 +@Component
  21 +@Order(20)
  22 +public class LineVersionsData extends Thread {
  23 +
  24 + static Logger logger = LoggerFactory.getLogger(LineVersionsData.class);
  25 +
  26 + @Autowired
  27 + LineVersionsService lineVersionsService;
  28 +
  29 + @Autowired
  30 + StationRouteService stationRouteService;
  31 +
  32 + @Override
  33 + public void run() {
  34 + logger.warn("线路版本更新开始");
  35 + try {
  36 + List<LineVersions> list = lineVersionsService.lineUpdate();
  37 + if(list.size() == 0){
  38 + logger.info("没有需要更新的线路!");
  39 + return;
  40 + }
  41 + for (LineVersions lineVersions : list) {
  42 + Integer lineId = lineVersions.getLine().getId();
  43 + // 更新线路文件
  44 + Map<String, Object> map = new HashMap<>();
  45 + map.put("lineId", lineId);
  46 + stationRouteService.usingSingle(map);
  47 + logger.info("线路版本更新成功!");
  48 + }
  49 + } catch (Exception e) {
  50 + e.printStackTrace();
  51 + logger.error("线路版本更新出现异常!", e);
  52 + }
  53 + logger.warn("线路版本更新结束");
  54 + }
  55 +}
src/main/java/com/bsth/data/car_out_info/CarOutInfoHandler.java
@@ -15,12 +15,8 @@ import org.slf4j.LoggerFactory; @@ -15,12 +15,8 @@ import org.slf4j.LoggerFactory;
15 import org.springframework.beans.factory.annotation.Autowired; 15 import org.springframework.beans.factory.annotation.Autowired;
16 import org.springframework.jdbc.core.BatchPreparedStatementSetter; 16 import org.springframework.jdbc.core.BatchPreparedStatementSetter;
17 import org.springframework.jdbc.core.JdbcTemplate; 17 import org.springframework.jdbc.core.JdbcTemplate;
18 -import org.springframework.jdbc.datasource.DataSourceTransactionManager;  
19 import org.springframework.stereotype.Component; 18 import org.springframework.stereotype.Component;
20 -import org.springframework.transaction.TransactionDefinition;  
21 import org.springframework.transaction.TransactionStatus; 19 import org.springframework.transaction.TransactionStatus;
22 -import org.springframework.transaction.support.DefaultTransactionDefinition;  
23 -import org.springframework.transaction.support.TransactionCallback;  
24 import org.springframework.transaction.support.TransactionCallbackWithoutResult; 20 import org.springframework.transaction.support.TransactionCallbackWithoutResult;
25 import org.springframework.transaction.support.TransactionTemplate; 21 import org.springframework.transaction.support.TransactionTemplate;
26 22
@@ -70,6 +66,7 @@ public class CarOutInfoHandler { @@ -70,6 +66,7 @@ public class CarOutInfoHandler {
70 * 全量更新发车信息表 66 * 全量更新发车信息表
71 */ 67 */
72 public void updateAll() { 68 public void updateAll() {
  69 + logger.warn("发车信息更新开始");
73 try{ 70 try{
74 //将班次按线路分组 71 //将班次按线路分组
75 List<ScheduleRealInfo> all = new ArrayList<>(dayOfSchedule.findAll()); 72 List<ScheduleRealInfo> all = new ArrayList<>(dayOfSchedule.findAll());
@@ -88,6 +85,7 @@ public class CarOutInfoHandler { @@ -88,6 +85,7 @@ public class CarOutInfoHandler {
88 }catch (Exception e){ 85 }catch (Exception e){
89 logger.error("", e); 86 logger.error("", e);
90 } 87 }
  88 + logger.warn("发车信息更新结束");
91 } 89 }
92 90
93 public List<ScheduleRealInfo> update(List<ScheduleRealInfo> list) { 91 public List<ScheduleRealInfo> update(List<ScheduleRealInfo> list) {
src/main/java/com/bsth/data/directive/DirectivesPstThread.java
@@ -14,11 +14,10 @@ import org.slf4j.LoggerFactory; @@ -14,11 +14,10 @@ import org.slf4j.LoggerFactory;
14 import org.springframework.beans.factory.annotation.Autowired; 14 import org.springframework.beans.factory.annotation.Autowired;
15 import org.springframework.jdbc.core.BatchPreparedStatementSetter; 15 import org.springframework.jdbc.core.BatchPreparedStatementSetter;
16 import org.springframework.jdbc.core.JdbcTemplate; 16 import org.springframework.jdbc.core.JdbcTemplate;
17 -import org.springframework.jdbc.datasource.DataSourceTransactionManager;  
18 import org.springframework.stereotype.Component; 17 import org.springframework.stereotype.Component;
19 -import org.springframework.transaction.TransactionDefinition;  
20 import org.springframework.transaction.TransactionStatus; 18 import org.springframework.transaction.TransactionStatus;
21 -import org.springframework.transaction.support.DefaultTransactionDefinition; 19 +import org.springframework.transaction.support.TransactionCallbackWithoutResult;
  20 +import org.springframework.transaction.support.TransactionTemplate;
22 21
23 import java.sql.PreparedStatement; 22 import java.sql.PreparedStatement;
24 import java.sql.SQLException; 23 import java.sql.SQLException;
@@ -48,10 +47,14 @@ public class DirectivesPstThread extends Thread { @@ -48,10 +47,14 @@ public class DirectivesPstThread extends Thread {
48 @Autowired 47 @Autowired
49 JdbcTemplate jdbcTemplate; 48 JdbcTemplate jdbcTemplate;
50 49
  50 + @Autowired
  51 + private TransactionTemplate transactionTemplate;
  52 +
51 private static DateTimeFormatter fmtyyyyMMdd = DateTimeFormat.forPattern("yyyy-MM-dd"); 53 private static DateTimeFormatter fmtyyyyMMdd = DateTimeFormat.forPattern("yyyy-MM-dd");
52 54
53 @Override 55 @Override
54 public void run() { 56 public void run() {
  57 + logger.warn("指令持久化开始");
55 try{ 58 try{
56 ConcurrentLinkedQueue<Directive> list = DayOfDirectives.pstDirectives; 59 ConcurrentLinkedQueue<Directive> list = DayOfDirectives.pstDirectives;
57 60
@@ -99,176 +102,172 @@ public class DirectivesPstThread extends Thread { @@ -99,176 +102,172 @@ public class DirectivesPstThread extends Thread {
99 }catch (Exception e){ 102 }catch (Exception e){
100 logger.error("指令入库出现异常", e); 103 logger.error("指令入库出现异常", e);
101 } 104 }
  105 + logger.warn("指令持久化结束");
102 } 106 }
103 107
104 private void save64(final List<D64> d64s) { 108 private void save64(final List<D64> d64s) {
105 if(null == d64s || d64s.size() == 0) 109 if(null == d64s || d64s.size() == 0)
106 return; 110 return;
107 111
  112 + logger.warn("64指令保存开始");
  113 +
108 String sql = "insert into bsth_v_directive_64(device_id,error_text,http_code,oper_code,rq,sender,timestamp,city_code,line_id,txt_content,resp_ack) " + 114 String sql = "insert into bsth_v_directive_64(device_id,error_text,http_code,oper_code,rq,sender,timestamp,city_code,line_id,txt_content,resp_ack) " +
109 " values(?,?,?,?,?,?,?,?,?,?,?)"; 115 " values(?,?,?,?,?,?,?,?,?,?,?)";
110 116
111 - //编程式事务  
112 - DataSourceTransactionManager tran = new DataSourceTransactionManager(jdbcTemplate.getDataSource());  
113 - DefaultTransactionDefinition def = new DefaultTransactionDefinition();  
114 - def.setPropagationBehavior(TransactionDefinition.PROPAGATION_REQUIRED);  
115 - TransactionStatus status = tran.getTransaction(def);  
116 -  
117 - try{  
118 - jdbcTemplate.batchUpdate(sql, new BatchPreparedStatementSetter() {  
119 - @Override  
120 - public void setValues(PreparedStatement ps, int i) throws SQLException {  
121 - D64 d64 = d64s.get(i);  
122 - ps.setString(1 , d64.getDeviceId());  
123 - ps.setString(2, isNvl(d64.getErrorText()));  
124 - ps.setInt(3, d64.getHttpCode());  
125 - ps.setShort(4, isNvl(d64.getOperCode()));  
126 - ps.setString(5, d64.getRq());  
127 -  
128 - ps.setString(6, isNvl(d64.getSender()));  
129 - ps.setLong(7, d64.getTimestamp());  
130 -  
131 - ps.setShort(8, isNvl(d64.getData().getCityCode()));  
132 - ps.setString(9, isNvl(d64.getData().getLineId()));  
133 - ps.setString(10, isNvl(d64.getData().getTxtContent()));  
134 - ps.setShort(11, isNvl(d64.getRespAck()));  
135 - }  
136 -  
137 - @Override  
138 - public int getBatchSize() {  
139 - return d64s.size(); 117 + transactionTemplate.execute(new TransactionCallbackWithoutResult() {
  118 +
  119 + @Override
  120 + protected void doInTransactionWithoutResult(TransactionStatus status) {
  121 + try {
  122 + jdbcTemplate.batchUpdate(sql, new BatchPreparedStatementSetter() {
  123 + @Override
  124 + public void setValues(PreparedStatement ps, int i) throws SQLException {
  125 + D64 d64 = d64s.get(i);
  126 + ps.setString(1 , d64.getDeviceId());
  127 + ps.setString(2, isNvl(d64.getErrorText()));
  128 + ps.setInt(3, d64.getHttpCode());
  129 + ps.setShort(4, isNvl(d64.getOperCode()));
  130 + ps.setString(5, d64.getRq());
  131 +
  132 + ps.setString(6, isNvl(d64.getSender()));
  133 + ps.setLong(7, d64.getTimestamp());
  134 +
  135 + ps.setShort(8, isNvl(d64.getData().getCityCode()));
  136 + ps.setString(9, isNvl(d64.getData().getLineId()));
  137 + ps.setString(10, isNvl(d64.getData().getTxtContent()));
  138 + ps.setShort(11, isNvl(d64.getRespAck()));
  139 + }
  140 +
  141 + @Override
  142 + public int getBatchSize() {
  143 + return d64s.size();
  144 + }
  145 + });
  146 + } catch (Exception e) {
  147 + logger.error(String.format("错误数据:%s", JSON.toJSONString(d64s)), e);
  148 + status.setRollbackOnly();
140 } 149 }
141 - });  
142 -  
143 - tran.commit(status);  
144 -  
145 - logger.info("64 入库成功: " + d64s.size());  
146 - }catch (Exception e){  
147 - logger.error(String.format("错误数据:%s", JSON.toJSONString(d64s)), e);  
148 - tran.rollback(status);  
149 - } 150 + }
  151 + });
  152 + logger.warn("64指令保存结束");
150 } 153 }
151 154
152 private void update60(final List<D60> d60s) { 155 private void update60(final List<D60> d60s) {
153 if(null == d60s || d60s.size() == 0) 156 if(null == d60s || d60s.size() == 0)
154 return; 157 return;
155 158
  159 + logger.warn("60指令更新开始");
156 String sql = "update bsth_v_directive_60 set reply46=?,reply46time=?,reply47=?,reply47time=? where device_id=? and timestamp=? and msg_id=?"; 160 String sql = "update bsth_v_directive_60 set reply46=?,reply46time=?,reply47=?,reply47time=? where device_id=? and timestamp=? and msg_id=?";
157 161
158 - //编程式事务  
159 - DataSourceTransactionManager tran = new DataSourceTransactionManager(jdbcTemplate.getDataSource());  
160 - DefaultTransactionDefinition def = new DefaultTransactionDefinition();  
161 - def.setPropagationBehavior(TransactionDefinition.PROPAGATION_REQUIRED);  
162 - TransactionStatus status = tran.getTransaction(def);  
163 -  
164 - try{  
165 - jdbcTemplate.batchUpdate(sql, new BatchPreparedStatementSetter() {  
166 - @Override  
167 - public void setValues(PreparedStatement ps, int i) throws SQLException {  
168 - D60 d60 = d60s.get(i);  
169 - ps.setShort(1, isNvl(d60.getReply46()));  
170 - if(null == d60.getReply46Time())  
171 - ps.setNull(2, Types.BIGINT);  
172 - else  
173 - ps.setLong(2, d60.getReply46Time());  
174 -  
175 - ps.setShort(3, isNvl(d60.getReply47()));  
176 -  
177 - if(null == d60.getReply47Time())  
178 - ps.setNull(4, Types.BIGINT);  
179 - else  
180 - ps.setLong(4, d60.getReply47Time());  
181 - ps.setString(5, d60.getDeviceId());  
182 - ps.setLong(6, d60.getTimestamp());  
183 - ps.setInt(7, d60.getMsgId());  
184 - }  
185 -  
186 - @Override  
187 - public int getBatchSize() {  
188 - return d60s.size(); 162 + transactionTemplate.execute(new TransactionCallbackWithoutResult() {
  163 +
  164 + @Override
  165 + protected void doInTransactionWithoutResult(TransactionStatus status) {
  166 + try{
  167 + jdbcTemplate.batchUpdate(sql, new BatchPreparedStatementSetter() {
  168 + @Override
  169 + public void setValues(PreparedStatement ps, int i) throws SQLException {
  170 + D60 d60 = d60s.get(i);
  171 + ps.setShort(1, isNvl(d60.getReply46()));
  172 + if(null == d60.getReply46Time())
  173 + ps.setNull(2, Types.BIGINT);
  174 + else
  175 + ps.setLong(2, d60.getReply46Time());
  176 +
  177 + ps.setShort(3, isNvl(d60.getReply47()));
  178 +
  179 + if(null == d60.getReply47Time())
  180 + ps.setNull(4, Types.BIGINT);
  181 + else
  182 + ps.setLong(4, d60.getReply47Time());
  183 + ps.setString(5, d60.getDeviceId());
  184 + ps.setLong(6, d60.getTimestamp());
  185 + ps.setInt(7, d60.getMsgId());
  186 + }
  187 +
  188 + @Override
  189 + public int getBatchSize() {
  190 + return d60s.size();
  191 + }
  192 + });
  193 + }catch (Exception e){
  194 + logger.error(String.format("错误数据:%s", JSON.toJSONString(d60s)), e);
  195 + status.setRollbackOnly();
189 } 196 }
190 - });  
191 -  
192 - tran.commit(status);  
193 -  
194 - logger.info("60 更新成功: " + d60s.size());  
195 - }catch (Exception e){  
196 - logger.error(String.format("错误数据:%s", JSON.toJSONString(d60s)), e);  
197 - tran.rollback(status);  
198 - } 197 + }
  198 + });
  199 + logger.warn("60指令更新结束");
199 } 200 }
200 201
201 private void save60(final List<D60> d60s) { 202 private void save60(final List<D60> d60s) {
202 if(null == d60s || d60s.size() == 0) 203 if(null == d60s || d60s.size() == 0)
203 return; 204 return;
204 205
  206 + logger.warn("60指令保存开始");
205 String sql = "insert into bsth_v_directive_60(device_id,error_text,http_code,oper_code,rq,sender,timestamp" + 207 String sql = "insert into bsth_v_directive_60(device_id,error_text,http_code,oper_code,rq,sender,timestamp" +
206 ",alarm_time,company_code,dispatch_instruct,instruct_type,msg_id,service_state,txt_content,is_dispatch" + 208 ",alarm_time,company_code,dispatch_instruct,instruct_type,msg_id,service_state,txt_content,is_dispatch" +
207 ",line_code,reply46,reply46time,reply47,reply47time,sch) " + 209 ",line_code,reply46,reply46time,reply47,reply47time,sch) " +
208 " values(?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)"; 210 " values(?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)";
209 211
210 - //编程式事务  
211 - DataSourceTransactionManager tran = new DataSourceTransactionManager(jdbcTemplate.getDataSource());  
212 - DefaultTransactionDefinition def = new DefaultTransactionDefinition();  
213 - def.setPropagationBehavior(TransactionDefinition.PROPAGATION_REQUIRED);  
214 - TransactionStatus status = tran.getTransaction(def);  
215 -  
216 - try{  
217 - jdbcTemplate.batchUpdate(sql, new BatchPreparedStatementSetter() {  
218 - @Override  
219 - public void setValues(PreparedStatement ps, int i) throws SQLException {  
220 - D60 d60 = d60s.get(i);  
221 - ps.setString(1, d60.getDeviceId());  
222 - ps.setString(2, isNvl(d60.getErrorText()));  
223 - ps.setInt(3, d60.getHttpCode());  
224 - ps.setShort(4, d60.getOperCode());  
225 - ps.setString(5, d60.getRq());  
226 - ps.setString(6, d60.getSender());  
227 - ps.setLong(7, d60.getTimestamp());  
228 -  
229 - ps.setLong(8, isNvl(d60.getData().getAlarmTime()));  
230 - ps.setShort(9, isNvl(d60.getData().getCompanyCode()));  
231 - ps.setShort(10, isNvl(d60.getData().getDispatchInstruct()));  
232 - ps.setInt(11, d60.getData().getInstructType());  
233 - ps.setInt(12, d60.getData().getMsgId());  
234 - ps.setLong(13, d60.getData().getServiceState());  
235 - ps.setString(14, d60.getData().getTxtContent());  
236 - ps.setBoolean(15, d60.isDispatch());  
237 -  
238 - ps.setString(16, isNvl(d60.getLineCode()));  
239 - ps.setShort(17, isNvl(d60.getReply46()));  
240 -  
241 - if(null == d60.getReply46Time())  
242 - ps.setNull(18, Types.BIGINT);  
243 - else  
244 - ps.setLong(18, d60.getReply46Time());  
245 -  
246 - ps.setShort(19, isNvl(d60.getReply47()));  
247 -  
248 - if(null == d60.getReply47Time())  
249 - ps.setNull(20, Types.BIGINT);  
250 - else  
251 - ps.setLong(20, d60.getReply47Time());  
252 -  
253 - if(d60.getSch()==null)  
254 - ps.setNull(21, Types.BIGINT);  
255 - else  
256 - ps.setLong(21, d60.getSch().getId()); 212 + transactionTemplate.execute(new TransactionCallbackWithoutResult() {
  213 +
  214 + @Override
  215 + protected void doInTransactionWithoutResult(TransactionStatus status) {
  216 + try{
  217 + jdbcTemplate.batchUpdate(sql, new BatchPreparedStatementSetter() {
  218 + @Override
  219 + public void setValues(PreparedStatement ps, int i) throws SQLException {
  220 + D60 d60 = d60s.get(i);
  221 + ps.setString(1, d60.getDeviceId());
  222 + ps.setString(2, isNvl(d60.getErrorText()));
  223 + ps.setInt(3, d60.getHttpCode());
  224 + ps.setShort(4, d60.getOperCode());
  225 + ps.setString(5, d60.getRq());
  226 + ps.setString(6, d60.getSender());
  227 + ps.setLong(7, d60.getTimestamp());
  228 +
  229 + ps.setLong(8, isNvl(d60.getData().getAlarmTime()));
  230 + ps.setShort(9, isNvl(d60.getData().getCompanyCode()));
  231 + ps.setShort(10, isNvl(d60.getData().getDispatchInstruct()));
  232 + ps.setInt(11, d60.getData().getInstructType());
  233 + ps.setInt(12, d60.getData().getMsgId());
  234 + ps.setLong(13, d60.getData().getServiceState());
  235 + ps.setString(14, d60.getData().getTxtContent());
  236 + ps.setBoolean(15, d60.isDispatch());
  237 +
  238 + ps.setString(16, isNvl(d60.getLineCode()));
  239 + ps.setShort(17, isNvl(d60.getReply46()));
  240 +
  241 + if(null == d60.getReply46Time())
  242 + ps.setNull(18, Types.BIGINT);
  243 + else
  244 + ps.setLong(18, d60.getReply46Time());
  245 +
  246 + ps.setShort(19, isNvl(d60.getReply47()));
  247 +
  248 + if(null == d60.getReply47Time())
  249 + ps.setNull(20, Types.BIGINT);
  250 + else
  251 + ps.setLong(20, d60.getReply47Time());
  252 +
  253 + if(d60.getSch()==null)
  254 + ps.setNull(21, Types.BIGINT);
  255 + else
  256 + ps.setLong(21, d60.getSch().getId());
  257 + }
  258 +
  259 + @Override
  260 + public int getBatchSize() {
  261 + return d60s.size();
  262 + }
  263 + });
  264 + }catch (Exception e){
  265 + logger.error(String.format("错误数据:%s", JSON.toJSONString(d60s)), e);
  266 + status.setRollbackOnly();
257 } 267 }
258 -  
259 - @Override  
260 - public int getBatchSize() {  
261 - return d60s.size();  
262 - }  
263 - });  
264 -  
265 - tran.commit(status);  
266 -  
267 - logger.info("60 入库成功: " + d60s.size());  
268 - }catch (Exception e){  
269 - logger.error(String.format("错误数据:%s", JSON.toJSONString(d60s)), e);  
270 - tran.rollback(status);  
271 - } 268 + }
  269 + });
  270 + logger.warn("60指令保存结束");
272 } 271 }
273 272
274 private String isNvl(String v) { 273 private String isNvl(String v) {
src/main/java/com/bsth/data/forecast/SampleTimeDataLoader.java
1 -package com.bsth.data.forecast;  
2 -  
3 -import java.util.ArrayList;  
4 -import java.util.Collections;  
5 -import java.util.Comparator;  
6 -import java.util.Date;  
7 -import java.util.Iterator;  
8 -import java.util.List;  
9 -import java.util.Set;  
10 -  
11 -import org.joda.time.format.DateTimeFormat;  
12 -import org.joda.time.format.DateTimeFormatter;  
13 -import org.slf4j.Logger;  
14 -import org.slf4j.LoggerFactory;  
15 -import org.springframework.beans.factory.annotation.Autowired;  
16 -import org.springframework.stereotype.Component;  
17 -  
18 -import com.bsth.data.forecast.entity.SimpleRoute;  
19 -import com.bsth.data.forecast.entity.SimpleRoute.TimeRange;  
20 -import com.bsth.entity.StationRoute;  
21 -import com.bsth.entity.forecast.Sample;  
22 -import com.bsth.repository.StationRouteRepository;  
23 -import com.bsth.repository.forecast.SampleRepository;  
24 -import com.google.common.collect.ArrayListMultimap;  
25 -  
26 -/**  
27 - *  
28 - * @Title: loadData  
29 - * @Description: TODO(从数据库加载数据)  
30 - */  
31 -@Component  
32 -public class SampleTimeDataLoader extends Thread {  
33 -  
34 - @Autowired  
35 - SampleRepository sampleRepository;  
36 -  
37 - @Autowired  
38 - StationRouteRepository stationRouteRepository;  
39 -  
40 - // 当天日期  
41 - String rq;  
42 -  
43 - private static DateTimeFormatter fmtyyyyMMddHHmm = DateTimeFormat.forPattern("yyyy-MM-ddHH:mm")  
44 - ,fmtyyyyMMdd = DateTimeFormat.forPattern("yyyy-MM-dd");  
45 -  
46 - Logger logger = LoggerFactory.getLogger(this.getClass());  
47 -  
48 - @Override  
49 - public void run() {  
50 - rq = fmtyyyyMMdd.print(new Date().getTime());  
51 -  
52 - Iterator<Sample> iterator = sampleRepository.findAll().iterator();  
53 - ArrayListMultimap<String, Sample> sampleMap = ArrayListMultimap.create();  
54 -  
55 - Sample sample;  
56 - String key;  
57 - while (iterator.hasNext()) {  
58 - sample = iterator.next();  
59 - key = sample.getLineCode() + "_" + sample.getUpdown() + "_" + sample.getsStation() + "_"  
60 - + sample.geteStation();  
61 - sampleMap.put(key, sample);  
62 - }  
63 -  
64 - // 加载全部路由信息  
65 - List<StationRoute> allRoutes = stationRouteRepository.findAllEffective();  
66 - // 线路和走向分组  
67 - ArrayListMultimap<String, StationRoute> groupMap = ArrayListMultimap.create();  
68 - for (StationRoute sr : allRoutes)  
69 - groupMap.put(sr.getLineCode() + "_" + sr.getDirections(), sr);  
70 -  
71 - ArrayListMultimap<String, SimpleRoute> lineSampleMapCopy = ArrayListMultimap.create();  
72 - // 排序路由链并附加各个时区耗时信息  
73 - StationRouteComp comp = new StationRouteComp();  
74 - Set<String> kys = groupMap.keySet();  
75 - List<StationRoute> routeList;  
76 - StationRoute sRoute;  
77 -  
78 - List<Sample> sapList;  
79 - for (String k : kys) {  
80 - routeList = groupMap.get(k);  
81 - // 排序  
82 - Collections.sort(routeList, comp);  
83 -  
84 - for (int i = 1; i < routeList.size(); i++) {  
85 - sRoute = routeList.get(i);  
86 -  
87 - sapList = sampleMap.get(k + "_" +routeList.get(i - 1).getStationCode() + "_" + sRoute.getStationCode());  
88 -  
89 - lineSampleMapCopy.put(k, createSimpleRoute(sRoute, sapList));  
90 - }  
91 - }  
92 -  
93 - ForecastRealServer.lineSampleMap = lineSampleMapCopy;  
94 - logger.info("SampleTimeDataLoader.... over...");  
95 - }  
96 -  
97 - private SimpleRoute createSimpleRoute(StationRoute sRoute, List<Sample> list) {  
98 - SimpleRoute simple = new SimpleRoute();  
99 -  
100 - simple.stationCode = sRoute.getStationCode();  
101 - simple.ranges = new ArrayList<>();  
102 -  
103 - try{  
104 - TimeRange tg;  
105 - for (Sample s : list) {  
106 - tg = new TimeRange();  
107 -  
108 - tg.startTime = fmtyyyyMMddHHmm.parseMillis(rq + s.getsDate());  
109 - tg.endTime = fmtyyyyMMddHHmm.parseMillis(rq + s.geteDate());  
110 - tg.runTime = s.getRunTime();  
111 - simple.ranges.add(tg);  
112 - }  
113 -  
114 - //排序  
115 - Collections.sort(simple.ranges);  
116 - }catch(Exception e){  
117 - logger.error("", e);  
118 - }  
119 - return simple;  
120 - }  
121 -  
122 - public static class StationRouteComp implements Comparator<StationRoute> {  
123 -  
124 - @Override  
125 - public int compare(StationRoute o1, StationRoute o2) {  
126 - return o1.getStationRouteCode() - o2.getStationRouteCode();  
127 - }  
128 - }  
129 -} 1 +package com.bsth.data.forecast;
  2 +
  3 +import java.util.ArrayList;
  4 +import java.util.Collections;
  5 +import java.util.Comparator;
  6 +import java.util.Date;
  7 +import java.util.Iterator;
  8 +import java.util.List;
  9 +import java.util.Set;
  10 +
  11 +import org.joda.time.format.DateTimeFormat;
  12 +import org.joda.time.format.DateTimeFormatter;
  13 +import org.slf4j.Logger;
  14 +import org.slf4j.LoggerFactory;
  15 +import org.springframework.beans.factory.annotation.Autowired;
  16 +import org.springframework.stereotype.Component;
  17 +
  18 +import com.bsth.data.forecast.entity.SimpleRoute;
  19 +import com.bsth.data.forecast.entity.SimpleRoute.TimeRange;
  20 +import com.bsth.entity.StationRoute;
  21 +import com.bsth.entity.forecast.Sample;
  22 +import com.bsth.repository.StationRouteRepository;
  23 +import com.bsth.repository.forecast.SampleRepository;
  24 +import com.google.common.collect.ArrayListMultimap;
  25 +
  26 +/**
  27 + *
  28 + * @Title: loadData
  29 + * @Description: TODO(从数据库加载数据)
  30 + */
  31 +@Component
  32 +public class SampleTimeDataLoader extends Thread {
  33 +
  34 + @Autowired
  35 + SampleRepository sampleRepository;
  36 +
  37 + @Autowired
  38 + StationRouteRepository stationRouteRepository;
  39 +
  40 + // 当天日期
  41 + String rq;
  42 +
  43 + private static DateTimeFormatter fmtyyyyMMddHHmm = DateTimeFormat.forPattern("yyyy-MM-ddHH:mm")
  44 + ,fmtyyyyMMdd = DateTimeFormat.forPattern("yyyy-MM-dd");
  45 +
  46 + Logger logger = LoggerFactory.getLogger(this.getClass());
  47 +
  48 + @Override
  49 + public void run() {
  50 + logger.warn("到离站预测样本加载开始");
  51 + rq = fmtyyyyMMdd.print(System.currentTimeMillis());
  52 +
  53 + Iterator<Sample> iterator = sampleRepository.findAll().iterator();
  54 + ArrayListMultimap<String, Sample> sampleMap = ArrayListMultimap.create();
  55 +
  56 + Sample sample;
  57 + String key;
  58 + while (iterator.hasNext()) {
  59 + sample = iterator.next();
  60 + key = sample.getLineCode() + "_" + sample.getUpdown() + "_" + sample.getsStation() + "_"
  61 + + sample.geteStation();
  62 + sampleMap.put(key, sample);
  63 + }
  64 +
  65 + // 加载全部路由信息
  66 + List<StationRoute> allRoutes = stationRouteRepository.findAllEffective();
  67 + // 线路和走向分组
  68 + ArrayListMultimap<String, StationRoute> groupMap = ArrayListMultimap.create();
  69 + for (StationRoute sr : allRoutes)
  70 + groupMap.put(sr.getLineCode() + "_" + sr.getDirections(), sr);
  71 +
  72 + ArrayListMultimap<String, SimpleRoute> lineSampleMapCopy = ArrayListMultimap.create();
  73 + // 排序路由链并附加各个时区耗时信息
  74 + StationRouteComp comp = new StationRouteComp();
  75 + Set<String> kys = groupMap.keySet();
  76 + List<StationRoute> routeList;
  77 + StationRoute sRoute;
  78 +
  79 + List<Sample> sapList;
  80 + for (String k : kys) {
  81 + routeList = groupMap.get(k);
  82 + // 排序
  83 + Collections.sort(routeList, comp);
  84 +
  85 + for (int i = 1; i < routeList.size(); i++) {
  86 + sRoute = routeList.get(i);
  87 +
  88 + sapList = sampleMap.get(k + "_" +routeList.get(i - 1).getStationCode() + "_" + sRoute.getStationCode());
  89 +
  90 + lineSampleMapCopy.put(k, createSimpleRoute(sRoute, sapList));
  91 + }
  92 + }
  93 +
  94 + ForecastRealServer.lineSampleMap = lineSampleMapCopy;
  95 + logger.warn("到离站预测样本加载结束");
  96 + }
  97 +
  98 + private SimpleRoute createSimpleRoute(StationRoute sRoute, List<Sample> list) {
  99 + SimpleRoute simple = new SimpleRoute();
  100 +
  101 + simple.stationCode = sRoute.getStationCode();
  102 + simple.ranges = new ArrayList<>();
  103 +
  104 + try{
  105 + TimeRange tg;
  106 + for (Sample s : list) {
  107 + tg = new TimeRange();
  108 +
  109 + tg.startTime = fmtyyyyMMddHHmm.parseMillis(rq + s.getsDate());
  110 + tg.endTime = fmtyyyyMMddHHmm.parseMillis(rq + s.geteDate());
  111 + tg.runTime = s.getRunTime();
  112 + simple.ranges.add(tg);
  113 + }
  114 +
  115 + //排序
  116 + Collections.sort(simple.ranges);
  117 + }catch(Exception e){
  118 + logger.error("", e);
  119 + }
  120 + return simple;
  121 + }
  122 +
  123 + public static class StationRouteComp implements Comparator<StationRoute> {
  124 +
  125 + @Override
  126 + public int compare(StationRoute o1, StationRoute o2) {
  127 + return o1.getStationRouteCode() - o2.getStationRouteCode();
  128 + }
  129 + }
  130 +}
src/main/java/com/bsth/data/gpsdata_v2/thread/GpsDataLoaderThread.java
1 -package com.bsth.data.gpsdata_v2.thread;  
2 -  
3 -import com.bsth.data.gpsdata_v2.DataHandleProcess;  
4 -import com.bsth.data.gpsdata_v2.entity.GpsEntity;  
5 -import com.bsth.data.gpsdata_v2.load.GatewayHttpLoader;  
6 -import com.bsth.data.gpsdata_v2.load.SocketClientLoader;  
7 -import org.slf4j.Logger;  
8 -import org.slf4j.LoggerFactory;  
9 -import org.springframework.beans.factory.annotation.Autowired;  
10 -import org.springframework.stereotype.Component;  
11 -  
12 -import java.util.List;  
13 -  
14 -/**  
15 - * Created by panzhao on 2017/1/11.  
16 - */  
17 -@Component  
18 -public class GpsDataLoaderThread extends Thread {  
19 -  
20 - Logger logger = LoggerFactory.getLogger(this.getClass());  
21 -  
22 - //0:从GPS客户端内存获取 -1:从网关获取  
23 - private static int flag = 0;  
24 -  
25 - public static void setFlag(int v) {  
26 - flag = v;  
27 - }  
28 -  
29 - @Autowired  
30 - DataHandleProcess handleProcess;  
31 -  
32 - @Override  
33 - public void run() {  
34 - try {  
35 - List<GpsEntity> list;  
36 - if (flag == 0)  
37 - list = SocketClientLoader.load();  
38 - else  
39 - list = GatewayHttpLoader.load();  
40 -  
41 - if(null != list && list.size() > 0)  
42 - handleProcess.handle(list);  
43 - } catch (Exception e) {  
44 - logger.error("", e);  
45 - }  
46 - } 1 +package com.bsth.data.gpsdata_v2.thread;
  2 +
  3 +import com.bsth.data.gpsdata_v2.DataHandleProcess;
  4 +import com.bsth.data.gpsdata_v2.entity.GpsEntity;
  5 +import com.bsth.data.gpsdata_v2.load.GatewayHttpLoader;
  6 +import com.bsth.data.gpsdata_v2.load.SocketClientLoader;
  7 +import org.slf4j.Logger;
  8 +import org.slf4j.LoggerFactory;
  9 +import org.springframework.beans.factory.annotation.Autowired;
  10 +import org.springframework.stereotype.Component;
  11 +
  12 +import java.util.List;
  13 +
  14 +/**
  15 + * Created by panzhao on 2017/1/11.
  16 + */
  17 +@Component
  18 +public class GpsDataLoaderThread extends Thread {
  19 +
  20 + Logger logger = LoggerFactory.getLogger(this.getClass());
  21 +
  22 + //0:从GPS客户端内存获取 -1:从网关获取
  23 + private static int flag = 0;
  24 +
  25 + public static void setFlag(int v) {
  26 + flag = v;
  27 + }
  28 +
  29 + @Autowired
  30 + DataHandleProcess handleProcess;
  31 +
  32 + @Override
  33 + public void run() {
  34 + logger.warn("GPS获取数据开始");
  35 + try {
  36 + List<GpsEntity> list;
  37 + if (flag == 0)
  38 + list = SocketClientLoader.load();
  39 + else
  40 + list = GatewayHttpLoader.load();
  41 +
  42 + if(null != list && list.size() > 0)
  43 + handleProcess.handle(list);
  44 + } catch (Exception e) {
  45 + logger.error("", e);
  46 + }
  47 + logger.warn("GPS获取数据结束");
  48 + }
47 } 49 }
48 \ No newline at end of file 50 \ No newline at end of file
src/main/java/com/bsth/data/gpsdata_v2/thread/OfflineMonitorThread.java
1 -package com.bsth.data.gpsdata_v2.thread;  
2 -  
3 -import com.bsth.data.gpsdata_v2.GpsRealData;  
4 -import com.bsth.data.gpsdata_v2.entity.GpsEntity;  
5 -import com.bsth.data.gpsdata_v2.handlers.overspeed.OverspeedProcess;  
6 -import com.bsth.websocket.handler.SendUtils;  
7 -import org.slf4j.Logger;  
8 -import org.slf4j.LoggerFactory;  
9 -import org.springframework.beans.factory.annotation.Autowired;  
10 -import org.springframework.stereotype.Component;  
11 -  
12 -import java.util.Collection;  
13 -  
14 -/**  
15 - * GPS掉离线监控  
16 - * Created by panzhao on 2017/1/11.  
17 - */  
18 -@Component  
19 -public class OfflineMonitorThread extends Thread{  
20 -  
21 - @Autowired  
22 - GpsRealData gpsRealData;  
23 -  
24 - //掉线阈值  
25 - private final static int LOSE_TIME = 1000 * 60 * 10;  
26 -  
27 - Logger logger = LoggerFactory.getLogger(this.getClass());  
28 -  
29 - @Autowired  
30 - SendUtils sendUtils;  
31 -  
32 - @Autowired  
33 - OverspeedProcess overspeedProcess;  
34 -  
35 - //无任务时 离线阈值  
36 - //private final static int OFFLINE_TIME = 1000 * 60 * 10;  
37 -  
38 - @Override  
39 - public void run() {  
40 - try{  
41 - long t = System.currentTimeMillis();  
42 - Collection<GpsEntity> list = gpsRealData.all();  
43 -  
44 - String state;  
45 - for(GpsEntity gps : list){  
46 - state = gps.getAbnormalStatus();  
47 -  
48 - if(state != null && state.equals("offline"))  
49 - continue;  
50 -  
51 - if (t - gps.getTimestamp() > LOSE_TIME){  
52 - gps.offline();  
53 -  
54 - //结束超速  
55 - overspeedProcess.offline(gps.getDeviceId());  
56 - //通知页面有设备掉线  
57 - sendUtils.deviceOffline(gps);  
58 - }  
59 - }  
60 - }catch (Exception e){  
61 - logger.error("", e);  
62 - }  
63 - }  
64 -} 1 +package com.bsth.data.gpsdata_v2.thread;
  2 +
  3 +import com.bsth.data.gpsdata_v2.GpsRealData;
  4 +import com.bsth.data.gpsdata_v2.entity.GpsEntity;
  5 +import com.bsth.data.gpsdata_v2.handlers.overspeed.OverspeedProcess;
  6 +import com.bsth.websocket.handler.SendUtils;
  7 +import org.slf4j.Logger;
  8 +import org.slf4j.LoggerFactory;
  9 +import org.springframework.beans.factory.annotation.Autowired;
  10 +import org.springframework.stereotype.Component;
  11 +
  12 +import java.util.Collection;
  13 +
  14 +/**
  15 + * GPS掉离线监控
  16 + * Created by panzhao on 2017/1/11.
  17 + */
  18 +@Component
  19 +public class OfflineMonitorThread extends Thread{
  20 +
  21 + @Autowired
  22 + GpsRealData gpsRealData;
  23 +
  24 + //掉线阈值
  25 + private final static int LOSE_TIME = 1000 * 60 * 10;
  26 +
  27 + Logger logger = LoggerFactory.getLogger(this.getClass());
  28 +
  29 + @Autowired
  30 + SendUtils sendUtils;
  31 +
  32 + @Autowired
  33 + OverspeedProcess overspeedProcess;
  34 +
  35 + //无任务时 离线阈值
  36 + //private final static int OFFLINE_TIME = 1000 * 60 * 10;
  37 +
  38 + @Override
  39 + public void run() {
  40 + logger.warn("GPS离线检查开始");
  41 + try{
  42 + long t = System.currentTimeMillis();
  43 + Collection<GpsEntity> list = gpsRealData.all();
  44 +
  45 + String state;
  46 + for(GpsEntity gps : list){
  47 + state = gps.getAbnormalStatus();
  48 +
  49 + if(state != null && state.equals("offline"))
  50 + continue;
  51 +
  52 + if (t - gps.getTimestamp() > LOSE_TIME){
  53 + gps.offline();
  54 +
  55 + //结束超速
  56 + overspeedProcess.offline(gps.getDeviceId());
  57 + //通知页面有设备掉线
  58 + sendUtils.deviceOffline(gps);
  59 + }
  60 + }
  61 + }catch (Exception e){
  62 + logger.error("", e);
  63 + }
  64 + logger.warn("GPS离线检查结束");
  65 + }
  66 +}
src/main/java/com/bsth/data/maintenance_plan/MtPlanDataLoadThread.java
1 package com.bsth.data.maintenance_plan; 1 package com.bsth.data.maintenance_plan;
2 2
3 -import com.alibaba.fastjson.JSON;  
4 import com.fasterxml.jackson.databind.ObjectMapper; 3 import com.fasterxml.jackson.databind.ObjectMapper;
5 import org.apache.http.HttpEntity; 4 import org.apache.http.HttpEntity;
6 import org.apache.http.client.config.RequestConfig; 5 import org.apache.http.client.config.RequestConfig;
@@ -27,6 +26,7 @@ import java.util.Map; @@ -27,6 +26,7 @@ import java.util.Map;
27 26
28 /** 27 /**
29 * 维修保养计划 28 * 维修保养计划
  29 + * @author Hill
30 */ 30 */
31 @Component 31 @Component
32 public class MtPlanDataLoadThread extends Thread implements InitializingBean { 32 public class MtPlanDataLoadThread extends Thread implements InitializingBean {
@@ -57,6 +57,7 @@ public class MtPlanDataLoadThread extends Thread implements InitializingBean { @@ -57,6 +57,7 @@ public class MtPlanDataLoadThread extends Thread implements InitializingBean {
57 57
58 @Override 58 @Override
59 public void run() { 59 public void run() {
  60 + logger.warn("维修保养计划获取数据开始");
60 List<MaintenancePlan> list; 61 List<MaintenancePlan> list;
61 StringBuilder sb = new StringBuilder(url); 62 StringBuilder sb = new StringBuilder(url);
62 try { 63 try {
@@ -92,6 +93,7 @@ public class MtPlanDataLoadThread extends Thread implements InitializingBean { @@ -92,6 +93,7 @@ public class MtPlanDataLoadThread extends Thread implements InitializingBean {
92 } catch (Exception e) { 93 } catch (Exception e) {
93 logger.error("维修保养计划接口报错了", e); 94 logger.error("维修保养计划接口报错了", e);
94 } 95 }
  96 + logger.warn("维修保养计划获取数据结束");
95 } 97 }
96 98
97 @Override 99 @Override
src/main/java/com/bsth/data/safe_driv/SafeDrivDataLoadThread.java
1 -package com.bsth.data.safe_driv;  
2 -  
3 -import com.alibaba.fastjson.JSON;  
4 -import org.apache.http.HttpEntity;  
5 -import org.apache.http.client.config.RequestConfig;  
6 -import org.apache.http.client.methods.CloseableHttpResponse;  
7 -import org.apache.http.client.methods.HttpGet;  
8 -import org.apache.http.impl.client.CloseableHttpClient;  
9 -import org.apache.http.impl.client.HttpClients;  
10 -import org.slf4j.Logger;  
11 -import org.slf4j.LoggerFactory;  
12 -import org.springframework.stereotype.Component;  
13 -  
14 -import java.io.BufferedReader;  
15 -import java.io.InputStreamReader;  
16 -import java.util.List;  
17 -  
18 -/**  
19 - * 安全驾驶数据加载线程  
20 - * Created by panzhao on 2017/4/6.  
21 - */  
22 -@Component  
23 -public class SafeDrivDataLoadThread extends Thread {  
24 -  
25 - Logger logger = LoggerFactory.getLogger(this.getClass());  
26 -  
27 - static String url;  
28 - static CloseableHttpClient httpClient;  
29 - static HttpGet get;  
30 - static RequestConfig requestConfig;  
31 - static CloseableHttpResponse response;  
32 - static HttpEntity entity;  
33 - static BufferedReader br;  
34 -  
35 - static {  
36 - url = "http://211.95.61.66:9008/safedriving/realtimeInterface";  
37 - httpClient = HttpClients.createDefault();  
38 - get = new HttpGet(url);  
39 - requestConfig = RequestConfig.custom()  
40 - .setConnectTimeout(5500).setConnectionRequestTimeout(5000)  
41 - .setSocketTimeout(5500).build();  
42 - get.setConfig(requestConfig);  
43 - }  
44 -  
45 - @Override  
46 - public void run() {  
47 - List<SafeDriv> list;  
48 - try {  
49 -  
50 - response = httpClient.execute(get);  
51 -  
52 - int statusCode = response.getStatusLine().getStatusCode();  
53 - if(statusCode != 200){  
54 - logger.error("http client status code: " + statusCode);  
55 - }  
56 -  
57 - entity = response.getEntity();  
58 - if (null != entity) {  
59 - br = new BufferedReader(new InputStreamReader(entity.getContent()));  
60 - StringBuffer stringBuffer = new StringBuffer();  
61 - String str = "";  
62 - while ((str = br.readLine()) != null)  
63 - stringBuffer.append(str);  
64 -  
65 -  
66 - list = JSON.parseArray(stringBuffer.toString(), SafeDriv.class);  
67 -  
68 - for (SafeDriv sd : list) {  
69 - SafeDrivCenter.put(sd);  
70 - }  
71 - }  
72 -  
73 - if (null != response)  
74 - response.close();  
75 - } catch (Exception e) {  
76 - logger.error("安全驾驶接口报错了", e);  
77 - }  
78 - }  
79 -} 1 +package com.bsth.data.safe_driv;
  2 +
  3 +import com.alibaba.fastjson.JSON;
  4 +import org.apache.http.HttpEntity;
  5 +import org.apache.http.client.config.RequestConfig;
  6 +import org.apache.http.client.methods.CloseableHttpResponse;
  7 +import org.apache.http.client.methods.HttpGet;
  8 +import org.apache.http.impl.client.CloseableHttpClient;
  9 +import org.apache.http.impl.client.HttpClients;
  10 +import org.slf4j.Logger;
  11 +import org.slf4j.LoggerFactory;
  12 +import org.springframework.stereotype.Component;
  13 +
  14 +import java.io.BufferedReader;
  15 +import java.io.InputStreamReader;
  16 +import java.util.List;
  17 +
  18 +/**
  19 + * 安全驾驶数据加载线程
  20 + * Created by panzhao on 2017/4/6.
  21 + */
  22 +@Component
  23 +public class SafeDrivDataLoadThread extends Thread {
  24 +
  25 + Logger logger = LoggerFactory.getLogger(this.getClass());
  26 +
  27 + static String url;
  28 + static CloseableHttpClient httpClient;
  29 + static HttpGet get;
  30 + static RequestConfig requestConfig;
  31 + static CloseableHttpResponse response;
  32 + static HttpEntity entity;
  33 + static BufferedReader br;
  34 +
  35 + static {
  36 + url = "http://211.95.61.66:9008/safedriving/realtimeInterface";
  37 + httpClient = HttpClients.createDefault();
  38 + get = new HttpGet(url);
  39 + requestConfig = RequestConfig.custom()
  40 + .setConnectTimeout(5500).setConnectionRequestTimeout(5000)
  41 + .setSocketTimeout(5500).build();
  42 + get.setConfig(requestConfig);
  43 + }
  44 +
  45 + @Override
  46 + public void run() {
  47 + logger.warn("安全驾驶获取数据开始");
  48 + List<SafeDriv> list;
  49 + try {
  50 +
  51 + response = httpClient.execute(get);
  52 +
  53 + int statusCode = response.getStatusLine().getStatusCode();
  54 + if(statusCode != 200){
  55 + logger.error("http client status code: " + statusCode);
  56 + }
  57 +
  58 + entity = response.getEntity();
  59 + if (null != entity) {
  60 + br = new BufferedReader(new InputStreamReader(entity.getContent()));
  61 + StringBuffer stringBuffer = new StringBuffer();
  62 + String str = "";
  63 + while ((str = br.readLine()) != null)
  64 + stringBuffer.append(str);
  65 +
  66 +
  67 + list = JSON.parseArray(stringBuffer.toString(), SafeDriv.class);
  68 +
  69 + for (SafeDriv sd : list) {
  70 + SafeDrivCenter.put(sd);
  71 + }
  72 + }
  73 +
  74 + if (null != response)
  75 + response.close();
  76 + } catch (Exception e) {
  77 + logger.error("安全驾驶接口报错了", e);
  78 + }
  79 + logger.warn("安全驾驶获取数据结束");
  80 + }
  81 +}
src/main/java/com/bsth/data/schedule/DayOfSchedule.java
@@ -15,6 +15,8 @@ import com.bsth.entity.schedule.SchedulePlanInfo; @@ -15,6 +15,8 @@ import com.bsth.entity.schedule.SchedulePlanInfo;
15 import com.bsth.repository.realcontrol.ScheduleRealInfoRepository; 15 import com.bsth.repository.realcontrol.ScheduleRealInfoRepository;
16 import com.bsth.service.schedule.SchedulePlanInfoService; 16 import com.bsth.service.schedule.SchedulePlanInfoService;
17 import com.bsth.websocket.handler.SendUtils; 17 import com.bsth.websocket.handler.SendUtils;
  18 +import com.fasterxml.jackson.core.JsonProcessingException;
  19 +import com.fasterxml.jackson.databind.ObjectMapper;
18 import com.google.common.collect.ArrayListMultimap; 20 import com.google.common.collect.ArrayListMultimap;
19 import com.google.common.collect.HashMultimap; 21 import com.google.common.collect.HashMultimap;
20 import com.google.common.collect.ListMultimap; 22 import com.google.common.collect.ListMultimap;
@@ -29,11 +31,10 @@ import org.springframework.beans.factory.annotation.Value; @@ -29,11 +31,10 @@ import org.springframework.beans.factory.annotation.Value;
29 import org.springframework.dao.DataIntegrityViolationException; 31 import org.springframework.dao.DataIntegrityViolationException;
30 import org.springframework.jdbc.core.BatchPreparedStatementSetter; 32 import org.springframework.jdbc.core.BatchPreparedStatementSetter;
31 import org.springframework.jdbc.core.JdbcTemplate; 33 import org.springframework.jdbc.core.JdbcTemplate;
32 -import org.springframework.jdbc.datasource.DataSourceTransactionManager;  
33 import org.springframework.stereotype.Component; 34 import org.springframework.stereotype.Component;
34 -import org.springframework.transaction.TransactionDefinition;  
35 import org.springframework.transaction.TransactionStatus; 35 import org.springframework.transaction.TransactionStatus;
36 -import org.springframework.transaction.support.DefaultTransactionDefinition; 36 +import org.springframework.transaction.support.TransactionCallbackWithoutResult;
  37 +import org.springframework.transaction.support.TransactionTemplate;
37 38
38 import java.sql.PreparedStatement; 39 import java.sql.PreparedStatement;
39 import java.sql.SQLException; 40 import java.sql.SQLException;
@@ -440,85 +441,84 @@ public class DayOfSchedule { @@ -440,85 +441,84 @@ public class DayOfSchedule {
440 item.setScheduleDateStr(sdfyyyyMMdd.format(item.getScheduleDate())); 441 item.setScheduleDateStr(sdfyyyyMMdd.format(item.getScheduleDate()));
441 } 442 }
442 443
443 - //编程式事务  
444 - DataSourceTransactionManager tran = new DataSourceTransactionManager(jdbcTemplate.getDataSource());  
445 - DefaultTransactionDefinition def = new DefaultTransactionDefinition();  
446 - def.setPropagationBehavior(TransactionDefinition.PROPAGATION_REQUIRED);  
447 - TransactionStatus status = tran.getTransaction(def);  
448 -  
449 - try{  
450 - final List<ScheduleRealInfo> pstList = list;  
451 - //写入  
452 - jdbcTemplate.batchUpdate("insert into bsth_c_s_sp_info_real(id,bc_type,bcs,bcsj,cl_zbh,create_date,dfsj,directive_state,fcno,fcsj,fcsj_actual,j_gh,j_name,jhlc,lp_name,qdz_code,qdz_name,real_exec_date,remarks,s_gh,s_name,schedule_date,schedule_date_str,sflj,sp_id,status,update_date,xl_bm,xl_dir,xl_name,zdsj,zdsj_actual,zdz_code,zdz_name,ccno,df_auto,fgs_bm,fgs_name,gs_bm,gs_name,online,adjust_exps,reissue,jhlc_orig,sigin_compate,drift_status,cc_service,major_station_name,rfid_state,first_rfid_state)" +  
453 - " VALUES (?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)", new BatchPreparedStatementSetter() {  
454 - @Override  
455 - public void setValues(PreparedStatement ps, int i) throws SQLException {  
456 - ScheduleRealInfo sch = pstList.get(i);  
457 - ps.setLong(1, sch.getId());  
458 - ps.setString(2, sch.getBcType());  
459 - ps.setInt(3, sch.getBcs()==null?0:sch.getBcs());  
460 - ps.setInt(4, sch.getBcsj()==null?0:sch.getBcsj());  
461 - ps.setString(5, sch.getClZbh());  
462 - ps.setTimestamp(6, new java.sql.Timestamp(sch.getCreateDate().getTime()));  
463 - ps.setString(7, sch.getDfsj());  
464 - ps.setInt(8, sch.getDirectiveState());  
465 - ps.setInt(9, sch.getFcno()==null?0:sch.getFcno());  
466 - ps.setString(10, sch.getFcsj());  
467 - ps.setString(11, sch.getFcsjActual());  
468 - ps.setString(12, sch.getjGh());  
469 - ps.setString(13, sch.getjName());  
470 - ps.setDouble(14, sch.getJhlc());  
471 - ps.setString(15, sch.getLpName());  
472 - ps.setString(16, sch.getQdzCode());  
473 - ps.setString(17, sch.getQdzName());  
474 - ps.setString(18, sch.getRealExecDate());  
475 - ps.setString(19, sch.getRemarks());  
476 - ps.setString(20, sch.getsGh());  
477 - ps.setString(21, sch.getsName());  
478 - ps.setTimestamp(22, new java.sql.Timestamp(sch.getScheduleDate().getTime()));  
479 - ps.setString(23, sch.getScheduleDateStr());  
480 - ps.setBoolean(24, sch.isSflj());  
481 - ps.setLong(25, sch.getSpId());  
482 - ps.setInt(26, sch.getStatus());  
483 - ps.setTimestamp(27, new java.sql.Timestamp(sch.getUpdateDate().getTime()));  
484 - ps.setString(28, sch.getXlBm());  
485 - ps.setString(29, sch.getXlDir());  
486 - ps.setString(30, sch.getXlName());  
487 - ps.setString(31, sch.getZdsj());  
488 - ps.setString(32, sch.getZdsjActual());  
489 - ps.setString(33, sch.getZdzCode());  
490 - ps.setString(34, sch.getZdzName());  
491 - ps.setInt(35, sch.getCcno()==null?0:sch.getCcno());  
492 - ps.setBoolean(36, sch.isDfAuto());  
493 - ps.setString(37, sch.getFgsBm());  
494 - ps.setString(38, sch.getFgsName());  
495 - ps.setString(39, sch.getGsBm());  
496 - ps.setString(40, sch.getGsName());  
497 - ps.setBoolean(41, sch.isOnline());  
498 - ps.setString(42, sch.getAdjustExps());  
499 - ps.setBoolean(43, sch.isReissue());  
500 - ps.setDouble(44, sch.getJhlcOrig());  
501 - ps.setInt(45, sch.getSiginCompate());  
502 - ps.setInt(46, sch.getDriftStatus());  
503 - ps.setBoolean(47, sch.isCcService());  
504 - ps.setString(48, sch.getMajorStationName());  
505 - ps.setInt(49, sch.getRfidState());  
506 - ps.setInt(50, sch.getFirstRfidState());  
507 - }  
508 -  
509 - @Override  
510 - public int getBatchSize() {  
511 - return pstList.size(); 444 + transactionTemplate.execute(new TransactionCallbackWithoutResult() {
  445 + @Override
  446 + protected void doInTransactionWithoutResult(TransactionStatus status) {
  447 + try{
  448 + final List<ScheduleRealInfo> pstList = list;
  449 + //写入
  450 + jdbcTemplate.batchUpdate("insert into bsth_c_s_sp_info_real(id,bc_type,bcs,bcsj,cl_zbh,create_date,dfsj,directive_state,fcno,fcsj,fcsj_actual,j_gh,j_name,jhlc,lp_name,qdz_code,qdz_name,real_exec_date,remarks,s_gh,s_name,schedule_date,schedule_date_str,sflj,sp_id,status,update_date,xl_bm,xl_dir,xl_name,zdsj,zdsj_actual,zdz_code,zdz_name,ccno,df_auto,fgs_bm,fgs_name,gs_bm,gs_name,online,adjust_exps,reissue,jhlc_orig,sigin_compate,drift_status,cc_service,major_station_name,rfid_state,first_rfid_state)" +
  451 + " VALUES (?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)", new BatchPreparedStatementSetter() {
  452 + @Override
  453 + public void setValues(PreparedStatement ps, int i) throws SQLException {
  454 + ScheduleRealInfo sch = pstList.get(i);
  455 + ps.setLong(1, sch.getId());
  456 + ps.setString(2, sch.getBcType());
  457 + ps.setInt(3, sch.getBcs()==null?0:sch.getBcs());
  458 + ps.setInt(4, sch.getBcsj()==null?0:sch.getBcsj());
  459 + ps.setString(5, sch.getClZbh());
  460 + ps.setTimestamp(6, new java.sql.Timestamp(sch.getCreateDate().getTime()));
  461 + ps.setString(7, sch.getDfsj());
  462 + ps.setInt(8, sch.getDirectiveState());
  463 + ps.setInt(9, sch.getFcno()==null?0:sch.getFcno());
  464 + ps.setString(10, sch.getFcsj());
  465 + ps.setString(11, sch.getFcsjActual());
  466 + ps.setString(12, sch.getjGh());
  467 + ps.setString(13, sch.getjName());
  468 + ps.setDouble(14, sch.getJhlc());
  469 + ps.setString(15, sch.getLpName());
  470 + ps.setString(16, sch.getQdzCode());
  471 + ps.setString(17, sch.getQdzName());
  472 + ps.setString(18, sch.getRealExecDate());
  473 + ps.setString(19, sch.getRemarks());
  474 + ps.setString(20, sch.getsGh());
  475 + ps.setString(21, sch.getsName());
  476 + ps.setTimestamp(22, new java.sql.Timestamp(sch.getScheduleDate().getTime()));
  477 + ps.setString(23, sch.getScheduleDateStr());
  478 + ps.setBoolean(24, sch.isSflj());
  479 + ps.setLong(25, sch.getSpId());
  480 + ps.setInt(26, sch.getStatus());
  481 + ps.setTimestamp(27, new java.sql.Timestamp(sch.getUpdateDate().getTime()));
  482 + ps.setString(28, sch.getXlBm());
  483 + ps.setString(29, sch.getXlDir());
  484 + ps.setString(30, sch.getXlName());
  485 + ps.setString(31, sch.getZdsj());
  486 + ps.setString(32, sch.getZdsjActual());
  487 + ps.setString(33, sch.getZdzCode());
  488 + ps.setString(34, sch.getZdzName());
  489 + ps.setInt(35, sch.getCcno()==null?0:sch.getCcno());
  490 + ps.setBoolean(36, sch.isDfAuto());
  491 + ps.setString(37, sch.getFgsBm());
  492 + ps.setString(38, sch.getFgsName());
  493 + ps.setString(39, sch.getGsBm());
  494 + ps.setString(40, sch.getGsName());
  495 + ps.setBoolean(41, sch.isOnline());
  496 + ps.setString(42, sch.getAdjustExps());
  497 + ps.setBoolean(43, sch.isReissue());
  498 + ps.setDouble(44, sch.getJhlcOrig());
  499 + ps.setInt(45, sch.getSiginCompate());
  500 + ps.setInt(46, sch.getDriftStatus());
  501 + ps.setBoolean(47, sch.isCcService());
  502 + ps.setString(48, sch.getMajorStationName());
  503 + ps.setInt(49, sch.getRfidState());
  504 + ps.setInt(50, sch.getFirstRfidState());
  505 + }
  506 +
  507 + @Override
  508 + public int getBatchSize() {
  509 + return pstList.size();
  510 + }
  511 + });
  512 + }catch (Exception e){
  513 + status.setRollbackOnly();
  514 + try {
  515 + logger.error(String.format("翻班实际排班数据批量保存异常: %s", mapper.writeValueAsString(list)), e);
  516 + } catch (JsonProcessingException jsonProcessingException) {
  517 + jsonProcessingException.printStackTrace();
  518 + }
512 } 519 }
513 - });  
514 -  
515 - tran.commit(status);  
516 - }catch (Exception e){  
517 - tran.rollback(status);  
518 - logger.error("real schedule batchSave error...", e);  
519 - }  
520 - // 入库  
521 - //new BatchSaveUtils<ScheduleRealInfo>().saveList(list, ScheduleRealInfo.class); 520 + }
  521 + });
522 } 522 }
523 523
524 public List<SchedulePlanInfo> cleanSchPlanItr(Iterator<SchedulePlanInfo> itrab) { 524 public List<SchedulePlanInfo> cleanSchPlanItr(Iterator<SchedulePlanInfo> itrab) {
@@ -993,6 +993,12 @@ public class DayOfSchedule { @@ -993,6 +993,12 @@ public class DayOfSchedule {
993 @Autowired 993 @Autowired
994 JdbcTemplate jdbcTemplate; 994 JdbcTemplate jdbcTemplate;
995 995
  996 + @Autowired
  997 + private TransactionTemplate transactionTemplate;
  998 +
  999 + @Autowired
  1000 + private ObjectMapper mapper;
  1001 +
996 /** 1002 /**
997 * 删除实际排班 1003 * 删除实际排班
998 * 1004 *
src/main/java/com/bsth/data/schedule/auto_exec/AutoExecScanThread.java
1 -package com.bsth.data.schedule.auto_exec;  
2 -  
3 -import com.bsth.data.LineConfigData;  
4 -import com.bsth.data.schedule.DayOfSchedule;  
5 -import com.bsth.entity.realcontrol.LineConfig;  
6 -import com.bsth.entity.realcontrol.ScheduleRealInfo;  
7 -import org.slf4j.Logger;  
8 -import org.slf4j.LoggerFactory;  
9 -import org.springframework.beans.factory.annotation.Autowired;  
10 -import org.springframework.stereotype.Component;  
11 -  
12 -import java.util.ArrayList;  
13 -import java.util.Collection;  
14 -import java.util.List;  
15 -  
16 -/**  
17 - * 班次自动执行扫描线程  
18 - * Created by panzhao on 2017/10/31.  
19 - */  
20 -@Component  
21 -public class AutoExecScanThread extends Thread{  
22 -  
23 -  
24 - @Autowired  
25 - LineConfigData lineConfigData;  
26 -  
27 - @Autowired  
28 - DayOfSchedule dayOfSchedule;  
29 -  
30 - @Autowired  
31 - RealScheduleAutoExecHandler realScheduleAutoExecHandler;  
32 -  
33 - Logger logger = LoggerFactory.getLogger(this.getClass());  
34 -  
35 - @Override  
36 - public void run() {  
37 - try{  
38 - //要自动执行的线路  
39 - List<String> autos = new ArrayList<>();  
40 - Collection<LineConfig> lcs = lineConfigData.getAll();  
41 -  
42 - for(LineConfig config : lcs){  
43 - if(config.isAutoExec()){  
44 - autos.add(config.getLine().getLineCode());  
45 - }  
46 - }  
47 -  
48 - if(autos.size()==0)  
49 - return;  
50 - List<ScheduleRealInfo> all = new ArrayList<>(dayOfSchedule.findAll());  
51 - for(ScheduleRealInfo sch : all){  
52 - if(autos.contains(sch.getXlBm())){  
53 - realScheduleAutoExecHandler.exec(sch);  
54 - }  
55 - }  
56 - }catch (Exception e){  
57 - logger.error("", e);  
58 - }  
59 - }  
60 -} 1 +package com.bsth.data.schedule.auto_exec;
  2 +
  3 +import com.bsth.data.LineConfigData;
  4 +import com.bsth.data.schedule.DayOfSchedule;
  5 +import com.bsth.entity.realcontrol.LineConfig;
  6 +import com.bsth.entity.realcontrol.ScheduleRealInfo;
  7 +import org.slf4j.Logger;
  8 +import org.slf4j.LoggerFactory;
  9 +import org.springframework.beans.factory.annotation.Autowired;
  10 +import org.springframework.stereotype.Component;
  11 +
  12 +import java.util.ArrayList;
  13 +import java.util.Collection;
  14 +import java.util.List;
  15 +
  16 +/**
  17 + * 班次自动执行扫描线程
  18 + * Created by panzhao on 2017/10/31.
  19 + */
  20 +@Component
  21 +public class AutoExecScanThread extends Thread{
  22 +
  23 +
  24 + @Autowired
  25 + LineConfigData lineConfigData;
  26 +
  27 + @Autowired
  28 + DayOfSchedule dayOfSchedule;
  29 +
  30 + @Autowired
  31 + RealScheduleAutoExecHandler realScheduleAutoExecHandler;
  32 +
  33 + Logger logger = LoggerFactory.getLogger(this.getClass());
  34 +
  35 + @Override
  36 + public void run() {
  37 + logger.warn("班次自动执行扫描开始");
  38 + try{
  39 + //要自动执行的线路
  40 + List<String> autos = new ArrayList<>();
  41 + Collection<LineConfig> lcs = lineConfigData.getAll();
  42 +
  43 + for(LineConfig config : lcs){
  44 + if(config.isAutoExec()){
  45 + autos.add(config.getLine().getLineCode());
  46 + }
  47 + }
  48 +
  49 + if(autos.size()==0)
  50 + return;
  51 + List<ScheduleRealInfo> all = new ArrayList<>(dayOfSchedule.findAll());
  52 + for(ScheduleRealInfo sch : all){
  53 + if(autos.contains(sch.getXlBm())){
  54 + realScheduleAutoExecHandler.exec(sch);
  55 + }
  56 + }
  57 + }catch (Exception e){
  58 + logger.error("", e);
  59 + }
  60 + logger.warn("班次自动执行扫描结束");
  61 + }
  62 +}
src/main/java/com/bsth/data/schedule/e_state_check/thread/FixedCheckStationCodeThread.java
1 -package com.bsth.data.schedule.e_state_check.thread;  
2 -  
3 -import com.bsth.data.schedule.e_state_check.ScheduleStationCodeChecker;  
4 -import org.slf4j.Logger;  
5 -import org.slf4j.LoggerFactory;  
6 -import org.springframework.beans.factory.annotation.Autowired;  
7 -import org.springframework.stereotype.Component;  
8 -  
9 -/**  
10 - * 定时检查班次站点编码线程  
11 - * Created by panzhao on 2018/4/2.  
12 - */  
13 -@Component  
14 -public class FixedCheckStationCodeThread extends Thread {  
15 -  
16 - @Autowired  
17 - ScheduleStationCodeChecker scheduleStationCodeChecker;  
18 -  
19 - Logger logger = LoggerFactory.getLogger(this.getClass());  
20 -  
21 - @Override  
22 - public void run() {  
23 - try {  
24 - scheduleStationCodeChecker.checkAll();  
25 - } catch (Exception e) {  
26 - logger.error("", e);  
27 - }  
28 - }  
29 -} 1 +package com.bsth.data.schedule.e_state_check.thread;
  2 +
  3 +import com.bsth.data.schedule.e_state_check.ScheduleStationCodeChecker;
  4 +import org.slf4j.Logger;
  5 +import org.slf4j.LoggerFactory;
  6 +import org.springframework.beans.factory.annotation.Autowired;
  7 +import org.springframework.stereotype.Component;
  8 +
  9 +/**
  10 + * 定时检查班次站点编码线程
  11 + * Created by panzhao on 2018/4/2.
  12 + */
  13 +@Component
  14 +public class FixedCheckStationCodeThread extends Thread {
  15 +
  16 + @Autowired
  17 + ScheduleStationCodeChecker scheduleStationCodeChecker;
  18 +
  19 + Logger logger = LoggerFactory.getLogger(this.getClass());
  20 +
  21 + @Override
  22 + public void run() {
  23 + logger.warn("班次站点编码检查开始");
  24 + try {
  25 + scheduleStationCodeChecker.checkAll();
  26 + } catch (Exception e) {
  27 + logger.error("", e);
  28 + }
  29 + logger.warn("班次站点编码检查结束");
  30 + }
  31 +}
src/main/java/com/bsth/data/schedule/edit_logs/SeiPstThread.java
@@ -28,6 +28,7 @@ public class SeiPstThread extends Thread{ @@ -28,6 +28,7 @@ public class SeiPstThread extends Thread{
28 28
29 @Override 29 @Override
30 public void run() { 30 public void run() {
  31 + log.warn("班次修正日志保存开始");
31 try{ 32 try{
32 List<SchEditInfo> pstList = new ArrayList<>(); 33 List<SchEditInfo> pstList = new ArrayList<>();
33 LinkedList<SchEditInfo> list = ScheduleModifyLogger.list; 34 LinkedList<SchEditInfo> list = ScheduleModifyLogger.list;
@@ -48,5 +49,6 @@ public class SeiPstThread extends Thread{ @@ -48,5 +49,6 @@ public class SeiPstThread extends Thread{
48 }catch (Exception e){ 49 }catch (Exception e){
49 log.error("", e); 50 log.error("", e);
50 } 51 }
  52 + log.warn("班次修正日志保存结束");
51 } 53 }
52 } 54 }
53 \ No newline at end of file 55 \ No newline at end of file
src/main/java/com/bsth/data/schedule/late_adjust/LateAdjustHandle.java
1 -  
2 -package com.bsth.data.schedule.late_adjust;  
3 -  
4 -import com.bsth.data.LineConfigData;  
5 -import com.bsth.data.gpsdata_v2.entity.GpsEntity;  
6 -import com.bsth.entity.realcontrol.LineConfig;  
7 -import com.bsth.entity.realcontrol.ScheduleRealInfo;  
8 -import com.bsth.util.Arith;  
9 -import com.bsth.websocket.handler.SendUtils;  
10 -import org.slf4j.Logger;  
11 -import org.slf4j.LoggerFactory;  
12 -import org.springframework.beans.BeansException;  
13 -import org.springframework.context.ApplicationContext;  
14 -import org.springframework.context.ApplicationContextAware;  
15 -import org.springframework.stereotype.Component;  
16 -  
17 -import java.util.Collection;  
18 -import java.util.concurrent.ConcurrentHashMap;  
19 -import java.util.concurrent.ConcurrentMap;  
20 -  
21 -/**  
22 - * 误点自动调整待发 处理程序  
23 - * <p>  
24 - * 注意 :这里的误点是指应发未到  
25 - * Created by panzhao on 2017/4/16.  
26 - */  
27 -@Component  
28 -public class LateAdjustHandle implements ApplicationContextAware {  
29 -  
30 - static LineConfigData lineConfigData;  
31 - static SendUtils sendUtils;  
32 -  
33 - static Logger logger = LoggerFactory.getLogger(LateAdjustHandle.class);  
34 -  
35 - /**  
36 - * 应发未到的班次 key : id  
37 - */  
38 - private static ConcurrentMap<Long, ScheduleRealInfo> lateSchMap = new ConcurrentHashMap<>();  
39 -  
40 -  
41 - /**  
42 - * 新增一个误点班次  
43 - *  
44 - * @param sch  
45 - */  
46 - public static void putLate(ScheduleRealInfo sch) {  
47 - try {  
48 - //线路配置  
49 - LineConfig config = lineConfigData.get(sch.getXlBm());  
50 - if (sch.getLateMinute() == 0) {  
51 - if (!config.isEnableYjtk())  
52 - return;  
53 -  
54 - sch.setLateMinute(sch.getXlDir().equals("0") ? config.getUpStopMinute() : config.getDownStopMinute());  
55 - }  
56 -  
57 - if (sch.getDfsj().compareTo(config.getYjtkStart()) > 0  
58 - && sch.getDfsj().compareTo(config.getYjtkEnd()) <= 0) {  
59 -  
60 - //班次压入  
61 - if (!lateSchMap.containsKey(sch.getId())) {  
62 - logger.info("29【应发未到 班次 " + sch.getClZbh() + " -" + sch.getDfsj() + " -id: " + sch.getId() + " -加入误点调整!");  
63 -  
64 - sch.setLate2(true);  
65 - lateSchMap.put(sch.getId(), sch);  
66 - //通知客户端  
67 - sendUtils.sendAutoWdtz(sch, null);  
68 - }  
69 - }  
70 -  
71 - } catch (Exception e) {  
72 - logger.error("", e);  
73 - }  
74 - }  
75 -  
76 -  
77 - /**  
78 - * 获取所有应发未到的班次  
79 - *  
80 - * @return  
81 - */  
82 - public static Collection<ScheduleRealInfo> allLateSch() {  
83 - return lateSchMap.values();  
84 - }  
85 -  
86 - public static void remove(ScheduleRealInfo sch) {  
87 - try {  
88 - if (lateSchMap.containsKey(sch.getId())) {  
89 - lateSchMap.remove(sch.getId());  
90 -  
91 - sch.setLate2(false);  
92 - sch.setLateMinute(0);  
93 - sch.setDfAuto(false);  
94 -  
95 - logger.info("移除误点调整 -" + sch.getClZbh() + " -time: " + sch.getDfsj() + " -id: " + sch.getId());  
96 - }  
97 - } catch (Exception e) {  
98 - logger.error("", e);  
99 - }  
100 - }  
101 -  
102 - /**  
103 - * 车辆到站 进站 进 的哪个班次,就调该车辆的下一个班次  
104 - *  
105 - * @param gps  
106 - */  
107 - public static void carArrive(GpsEntity gps, ScheduleRealInfo sch) {  
108 - try {  
109 - if (gps.getInstation() <= 0 || null == sch)  
110 - return;  
111 -  
112 - if (!lateSchMap.containsKey(sch.getId())) {  
113 - //班次是否误点(可能处于误点线程扫描的空隙,所以再判定一次)  
114 - if (sch.getDfsjT() <= gps.getTimestamp()) {  
115 - putLate(sch);  
116 -  
117 - if (!lateSchMap.containsKey(sch.getId()))  
118 - return;  
119 -  
120 - logger.info("线程空隙漏掉的误点,id: " + sch.getId());  
121 - } else  
122 - return;  
123 - }  
124 -  
125 -  
126 - //可能是延迟信号,gps时间没有误点  
127 - if (gps.getTimestamp() <= sch.getDfsjT()) {  
128 - sch.setLate2(false);  
129 - lateSchMap.remove(sch.getId());  
130 - return;  
131 - }  
132 -  
133 -  
134 - //自动调整待发 到达时间 + 停靠时间  
135 - long dt = Arith.addLong(gps.getTimestamp(), (sch.getLateMinute() * 60 * 1000));  
136 -  
137 - sch.setDfsjAll(dt);  
138 - sch.setDfAuto(true);  
139 - //取消应发未到标记  
140 - sch.setLate2(false);  
141 -  
142 - lateSchMap.remove(sch.getId());  
143 - logger.info("【应发未到】车辆到站 " + sch.getClZbh() + " -" + sch.getDfsj() + " -到站时间:" + gps.getTimestamp() + " -停靠时间:" + sch.getLateMinute() + " -自动设置的待发时间:" + dt + " -id:" + sch.getId());  
144 - } catch (Exception e) {  
145 - e.printStackTrace();  
146 - logger.error("late2 car arrive", e);  
147 - }  
148 - }  
149 -  
150 -  
151 - @Override  
152 - public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {  
153 - lineConfigData = applicationContext.getBean(LineConfigData.class);  
154 - sendUtils = applicationContext.getBean(SendUtils.class);  
155 - } 1 +
  2 +package com.bsth.data.schedule.late_adjust;
  3 +
  4 +import com.bsth.data.LineConfigData;
  5 +import com.bsth.data.gpsdata_v2.entity.GpsEntity;
  6 +import com.bsth.entity.realcontrol.LineConfig;
  7 +import com.bsth.entity.realcontrol.ScheduleRealInfo;
  8 +import com.bsth.util.Arith;
  9 +import com.bsth.websocket.handler.SendUtils;
  10 +import org.slf4j.Logger;
  11 +import org.slf4j.LoggerFactory;
  12 +import org.springframework.beans.BeansException;
  13 +import org.springframework.context.ApplicationContext;
  14 +import org.springframework.context.ApplicationContextAware;
  15 +import org.springframework.stereotype.Component;
  16 +
  17 +import java.util.Collection;
  18 +import java.util.concurrent.ConcurrentHashMap;
  19 +import java.util.concurrent.ConcurrentMap;
  20 +
  21 +/**
  22 + * 误点自动调整待发 处理程序
  23 + * <p>
  24 + * 注意 :这里的误点是指应发未到
  25 + * Created by panzhao on 2017/4/16.
  26 + */
  27 +@Component
  28 +public class LateAdjustHandle implements ApplicationContextAware {
  29 +
  30 + static LineConfigData lineConfigData;
  31 + static SendUtils sendUtils;
  32 +
  33 + static Logger logger = LoggerFactory.getLogger(LateAdjustHandle.class);
  34 +
  35 + /**
  36 + * 应发未到的班次 key : id
  37 + */
  38 + private static ConcurrentMap<Long, ScheduleRealInfo> lateSchMap = new ConcurrentHashMap<>();
  39 +
  40 +
  41 + /**
  42 + * 新增一个误点班次
  43 + *
  44 + * @param sch
  45 + */
  46 + public static void putLate(ScheduleRealInfo sch) {
  47 + try {
  48 + //线路配置
  49 + LineConfig config = lineConfigData.get(sch.getXlBm());
  50 + if (sch.getLateMinute() == 0) {
  51 + if (!config.isEnableYjtk())
  52 + return;
  53 +
  54 + sch.setLateMinute(sch.getXlDir().equals("0") ? config.getUpStopMinute() : config.getDownStopMinute());
  55 + }
  56 +
  57 + if (sch.getDfsj().compareTo(config.getYjtkStart()) > 0
  58 + && sch.getDfsj().compareTo(config.getYjtkEnd()) <= 0) {
  59 +
  60 + //班次压入
  61 + if (!lateSchMap.containsKey(sch.getId())) {
  62 + logger.info("【应发未到】 班次 " + sch.getClZbh() + " -" + sch.getDfsj() + " -id: " + sch.getId() + " -加入误点调整!");
  63 +
  64 + sch.setLate2(true);
  65 + lateSchMap.put(sch.getId(), sch);
  66 + //通知客户端
  67 + sendUtils.sendAutoWdtz(sch, null);
  68 + }
  69 + }
  70 +
  71 + } catch (Exception e) {
  72 + logger.error("", e);
  73 + }
  74 + }
  75 +
  76 +
  77 + /**
  78 + * 获取所有应发未到的班次
  79 + *
  80 + * @return
  81 + */
  82 + public static Collection<ScheduleRealInfo> allLateSch() {
  83 + return lateSchMap.values();
  84 + }
  85 +
  86 + public static void remove(ScheduleRealInfo sch) {
  87 + try {
  88 + if (lateSchMap.containsKey(sch.getId())) {
  89 + lateSchMap.remove(sch.getId());
  90 +
  91 + sch.setLate2(false);
  92 + sch.setLateMinute(0);
  93 + sch.setDfAuto(false);
  94 +
  95 + logger.info("移除误点调整 -" + sch.getClZbh() + " -time: " + sch.getDfsj() + " -id: " + sch.getId());
  96 + }
  97 + } catch (Exception e) {
  98 + logger.error("", e);
  99 + }
  100 + }
  101 +
  102 + /**
  103 + * 车辆到站 进站 进 的哪个班次,就调该车辆的下一个班次
  104 + *
  105 + * @param gps
  106 + */
  107 + public static void carArrive(GpsEntity gps, ScheduleRealInfo sch) {
  108 + try {
  109 + if (gps.getInstation() <= 0 || null == sch)
  110 + return;
  111 +
  112 + if (!lateSchMap.containsKey(sch.getId())) {
  113 + //班次是否误点(可能处于误点线程扫描的空隙,所以再判定一次)
  114 + if (sch.getDfsjT() <= gps.getTimestamp()) {
  115 + putLate(sch);
  116 +
  117 + if (!lateSchMap.containsKey(sch.getId()))
  118 + return;
  119 +
  120 + logger.info("线程空隙漏掉的误点,id: " + sch.getId());
  121 + } else
  122 + return;
  123 + }
  124 +
  125 +
  126 + //可能是延迟信号,gps时间没有误点
  127 + if (gps.getTimestamp() <= sch.getDfsjT()) {
  128 + sch.setLate2(false);
  129 + lateSchMap.remove(sch.getId());
  130 + return;
  131 + }
  132 +
  133 +
  134 + //自动调整待发 到达时间 + 停靠时间
  135 + long dt = Arith.addLong(gps.getTimestamp(), (sch.getLateMinute() * 60 * 1000));
  136 +
  137 + sch.setDfsjAll(dt);
  138 + sch.setDfAuto(true);
  139 + //取消应发未到标记
  140 + sch.setLate2(false);
  141 +
  142 + lateSchMap.remove(sch.getId());
  143 + logger.info("【应发未到】车辆到站 " + sch.getClZbh() + " -" + sch.getDfsj() + " -到站时间:" + gps.getTimestamp() + " -停靠时间:" + sch.getLateMinute() + " -自动设置的待发时间:" + dt + " -id:" + sch.getId());
  144 + } catch (Exception e) {
  145 + e.printStackTrace();
  146 + logger.error("late2 car arrive", e);
  147 + }
  148 + }
  149 +
  150 +
  151 + @Override
  152 + public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
  153 + lineConfigData = applicationContext.getBean(LineConfigData.class);
  154 + sendUtils = applicationContext.getBean(SendUtils.class);
  155 + }
156 } 156 }
157 \ No newline at end of file 157 \ No newline at end of file
src/main/java/com/bsth/data/schedule/late_adjust/ScheduleLateThread.java
1 -package com.bsth.data.schedule.late_adjust;  
2 -  
3 -  
4 -import com.bsth.data.schedule.DayOfSchedule;  
5 -import com.bsth.data.schedule.ScheduleComparator;  
6 -import com.bsth.entity.realcontrol.ScheduleRealInfo;  
7 -import com.bsth.websocket.handler.SendUtils;  
8 -import org.apache.commons.lang3.StringUtils;  
9 -import org.slf4j.Logger;  
10 -import org.slf4j.LoggerFactory;  
11 -import org.springframework.beans.factory.annotation.Autowired;  
12 -import org.springframework.stereotype.Component;  
13 -  
14 -import java.util.ArrayList;  
15 -import java.util.Collections;  
16 -import java.util.Comparator;  
17 -import java.util.List;  
18 -  
19 -/**  
20 - *  
21 - * @ClassName: ScheduleLateThread  
22 - * @Description: TODO(班次误点扫描线程)  
23 - * @author PanZhao  
24 - * @date 2016年8月31日 下午3:09:02  
25 - *  
26 - */  
27 -@Component  
28 -public class ScheduleLateThread extends Thread{  
29 -  
30 - @Autowired  
31 - DayOfSchedule dayOfSchedule;  
32 -  
33 - @Autowired  
34 - SendUtils sendUtils;  
35 -  
36 - Logger logger = LoggerFactory.getLogger(this.getClass());  
37 -  
38 - private static Comparator<ScheduleRealInfo> cpm = new ScheduleComparator.DFSJ2();  
39 -  
40 - @Override  
41 - public void run() {  
42 - try{  
43 - List<ScheduleRealInfo> all = new ArrayList<>(dayOfSchedule.findAll());  
44 - Collections.sort(all, cpm);  
45 -  
46 - long t = System.currentTimeMillis();  
47 - int size = all.size();  
48 -  
49 - ScheduleRealInfo sch;  
50 - for(int i = 0; i < size; i ++){  
51 - sch = all.get(i);  
52 - if(sch.getDfsjT() > t)  
53 - break;  
54 -  
55 - if(sch.isLate())  
56 - continue;  
57 -  
58 - if(sch.getStatus() == 0  
59 - && StringUtils.isEmpty(sch.getFcsjActual())){  
60 -  
61 - //检查应发未到 当前班次无起点到达时间  
62 - if(StringUtils.isEmpty(sch.getQdzArrDatesj())){  
63 - ScheduleRealInfo prev = dayOfSchedule.prev(sch);  
64 - //上一个班次也没有实际终点到达时间  
65 - if(prev != null && StringUtils.isEmpty(prev.getZdsjActual())){  
66 - //进入误点调整程序  
67 - LateAdjustHandle.putLate(sch);  
68 - }  
69 - }  
70 -  
71 - //应发未发  
72 - sch.setLate(true);  
73 - //通知客户端  
74 - sendUtils.refreshSch(sch);  
75 - }  
76 - }  
77 - }catch (Exception e){  
78 - logger.error("", e);  
79 - }  
80 - } 1 +package com.bsth.data.schedule.late_adjust;
  2 +
  3 +
  4 +import com.bsth.data.schedule.DayOfSchedule;
  5 +import com.bsth.data.schedule.ScheduleComparator;
  6 +import com.bsth.entity.realcontrol.ScheduleRealInfo;
  7 +import com.bsth.websocket.handler.SendUtils;
  8 +import org.apache.commons.lang3.StringUtils;
  9 +import org.slf4j.Logger;
  10 +import org.slf4j.LoggerFactory;
  11 +import org.springframework.beans.factory.annotation.Autowired;
  12 +import org.springframework.stereotype.Component;
  13 +
  14 +import java.util.ArrayList;
  15 +import java.util.Collections;
  16 +import java.util.Comparator;
  17 +import java.util.List;
  18 +
  19 +/**
  20 + *
  21 + * @ClassName: ScheduleLateThread
  22 + * @Description: TODO(班次误点扫描线程)
  23 + * @author PanZhao
  24 + * @date 2016年8月31日 下午3:09:02
  25 + *
  26 + */
  27 +@Component
  28 +public class ScheduleLateThread extends Thread{
  29 +
  30 + @Autowired
  31 + DayOfSchedule dayOfSchedule;
  32 +
  33 + @Autowired
  34 + SendUtils sendUtils;
  35 +
  36 + Logger logger = LoggerFactory.getLogger(this.getClass());
  37 +
  38 + private static Comparator<ScheduleRealInfo> cpm = new ScheduleComparator.DFSJ2();
  39 +
  40 + @Override
  41 + public void run() {
  42 + logger.warn("班次误点扫描开始");
  43 + try{
  44 + List<ScheduleRealInfo> all = new ArrayList<>(dayOfSchedule.findAll());
  45 + Collections.sort(all, cpm);
  46 +
  47 + long t = System.currentTimeMillis();
  48 + int size = all.size();
  49 +
  50 + ScheduleRealInfo sch;
  51 + for(int i = 0; i < size; i ++){
  52 + sch = all.get(i);
  53 + if(sch.getDfsjT() > t)
  54 + break;
  55 +
  56 + if(sch.isLate())
  57 + continue;
  58 +
  59 + if(sch.getStatus() == 0
  60 + && StringUtils.isEmpty(sch.getFcsjActual())){
  61 +
  62 + //检查应发未到 当前班次无起点到达时间
  63 + if(StringUtils.isEmpty(sch.getQdzArrDatesj())){
  64 + ScheduleRealInfo prev = dayOfSchedule.prev(sch);
  65 + //上一个班次也没有实际终点到达时间
  66 + if(prev != null && StringUtils.isEmpty(prev.getZdsjActual())){
  67 + //进入误点调整程序
  68 + LateAdjustHandle.putLate(sch);
  69 + }
  70 + }
  71 +
  72 + //应发未发
  73 + sch.setLate(true);
  74 + //通知客户端
  75 + sendUtils.refreshSch(sch);
  76 + }
  77 + }
  78 + }catch (Exception e){
  79 + logger.error("", e);
  80 + }
  81 + logger.warn("班次误点扫描结束");
  82 + }
81 } 83 }
82 \ No newline at end of file 84 \ No newline at end of file
src/main/java/com/bsth/data/schedule/thread/SchedulePstThread.java
@@ -54,7 +54,7 @@ public class SchedulePstThread extends Thread { @@ -54,7 +54,7 @@ public class SchedulePstThread extends Thread {
54 54
55 @Override 55 @Override
56 public void run() { 56 public void run() {
57 - 57 + logger.warn("班次批量保存开始");
58 try{ 58 try{
59 ScheduleRealInfo schedule; 59 ScheduleRealInfo schedule;
60 for (int i = 0; i < 500; i++) { 60 for (int i = 0; i < 500; i++) {
@@ -75,6 +75,7 @@ public class SchedulePstThread extends Thread { @@ -75,6 +75,7 @@ public class SchedulePstThread extends Thread {
75 }catch (Exception e){ 75 }catch (Exception e){
76 logger.error("", e); 76 logger.error("", e);
77 } 77 }
  78 + logger.warn("班次批量保存结束");
78 } 79 }
79 80
80 private void save(){ 81 private void save(){
src/main/java/com/bsth/data/schedule/thread/ScheduleRefreshThread.java
1 -package com.bsth.data.schedule.thread;  
2 -  
3 -import com.bsth.data.LineConfigData;  
4 -import com.bsth.data.directive.DayOfDirectives;  
5 -import com.bsth.data.gpsdata_v2.cache.GpsCacheData;  
6 -import com.bsth.data.pilot80.PilotReport;  
7 -import com.bsth.data.schedule.DayOfSchedule;  
8 -import com.bsth.data.schedule.f_a_l.FirstAndLastHandler;  
9 -import com.bsth.entity.realcontrol.LineConfig;  
10 -import org.slf4j.Logger;  
11 -import org.slf4j.LoggerFactory;  
12 -import org.springframework.beans.factory.annotation.Autowired;  
13 -import org.springframework.stereotype.Component;  
14 -  
15 -import java.util.Collection;  
16 -import java.util.Set;  
17 -  
18 -/**  
19 - *  
20 - * @ClassName: ScheduleRefreshThread  
21 - * @Description: TODO(班次刷新线程,用于在营运开始时间切换到当日排班)  
22 - * @author PanZhao  
23 - * @date 2016年8月17日 下午1:23:34  
24 - *  
25 - */  
26 -@Component  
27 -public class ScheduleRefreshThread extends Thread{  
28 -  
29 - @Autowired  
30 - DayOfSchedule dayOfSchedule;  
31 -  
32 - @Autowired  
33 - LineConfigData lineConfs;  
34 -  
35 - @Autowired  
36 - DayOfDirectives dayOfDirectives;  
37 -  
38 - @Autowired  
39 - PilotReport pilotReport;  
40 -  
41 - Logger logger = LoggerFactory.getLogger(ScheduleRefreshThread.class);  
42 -  
43 - @Override  
44 - public void run() {  
45 - try {  
46 - Collection<LineConfig> confs = lineConfs.getAll();  
47 -  
48 - String currSchDate, oldSchDate;  
49 - String lineCode = null;  
50 - for(LineConfig conf : confs){  
51 - try{  
52 - lineCode = conf.getLine().getLineCode();  
53 - oldSchDate = dayOfSchedule.getCurrSchDate().get(lineCode);  
54 - currSchDate = dayOfSchedule.calcSchDate(lineCode);  
55 -  
56 - if(oldSchDate == null || !oldSchDate.equals(currSchDate)){  
57 -  
58 - try{  
59 - Set<String> cars = dayOfSchedule.findCarByLineCode(lineCode);  
60 - for(String car : cars){  
61 - GpsCacheData.remove(car);  
62 - dayOfSchedule.resetRepairReport(car);  
63 - }  
64 - //清除驾驶员上报数据  
65 - pilotReport.clear(lineCode);  
66 - //清除指令数据 指令数据,直接定时全部清空  
67 - //dayOfDirectives.clear(lineCode);  
68 - }catch (Exception e){  
69 - logger.error("清理 60 和 80出现问题", e);  
70 - }  
71 -  
72 - //重载排班数据  
73 - dayOfSchedule.reloadSch(lineCode, currSchDate, false);  
74 - logger.info(lineCode + "翻班完成, " + currSchDate + " -班次数量:" + dayOfSchedule.findByLineCode(lineCode).size());  
75 - }  
76 - }catch (Exception e){  
77 - logger.error("班次更新失败!! -" + lineCode, e);  
78 - }  
79 - }  
80 -  
81 - //按公司编码索引数据  
82 - dayOfSchedule.groupByGsbm();  
83 -  
84 - //首末班入库(给网关用的数据)  
85 - FirstAndLastHandler.saveAll();  
86 - } catch (Exception e) {  
87 - logger.error("", e);  
88 - }  
89 - }  
90 -} 1 +package com.bsth.data.schedule.thread;
  2 +
  3 +import com.bsth.data.LineConfigData;
  4 +import com.bsth.data.directive.DayOfDirectives;
  5 +import com.bsth.data.gpsdata_v2.cache.GpsCacheData;
  6 +import com.bsth.data.pilot80.PilotReport;
  7 +import com.bsth.data.schedule.DayOfSchedule;
  8 +import com.bsth.data.schedule.f_a_l.FirstAndLastHandler;
  9 +import com.bsth.entity.realcontrol.LineConfig;
  10 +import org.slf4j.Logger;
  11 +import org.slf4j.LoggerFactory;
  12 +import org.springframework.beans.factory.annotation.Autowired;
  13 +import org.springframework.stereotype.Component;
  14 +
  15 +import java.util.Collection;
  16 +import java.util.Set;
  17 +
  18 +/**
  19 + *
  20 + * @ClassName: ScheduleRefreshThread
  21 + * @Description: TODO(班次刷新线程,用于在营运开始时间切换到当日排班)
  22 + * @author PanZhao
  23 + * @date 2016年8月17日 下午1:23:34
  24 + *
  25 + */
  26 +@Component
  27 +public class ScheduleRefreshThread extends Thread{
  28 +
  29 + @Autowired
  30 + DayOfSchedule dayOfSchedule;
  31 +
  32 + @Autowired
  33 + LineConfigData lineConfs;
  34 +
  35 + @Autowired
  36 + DayOfDirectives dayOfDirectives;
  37 +
  38 + @Autowired
  39 + PilotReport pilotReport;
  40 +
  41 + Logger logger = LoggerFactory.getLogger(ScheduleRefreshThread.class);
  42 +
  43 + @Override
  44 + public void run() {
  45 + logger.warn("班次刷新开始");
  46 + try {
  47 + Collection<LineConfig> confs = lineConfs.getAll();
  48 +
  49 + String currSchDate, oldSchDate;
  50 + String lineCode = null;
  51 + for(LineConfig conf : confs){
  52 + try{
  53 + lineCode = conf.getLine().getLineCode();
  54 + oldSchDate = dayOfSchedule.getCurrSchDate().get(lineCode);
  55 + currSchDate = dayOfSchedule.calcSchDate(lineCode);
  56 +
  57 + if(oldSchDate == null || !oldSchDate.equals(currSchDate)){
  58 +
  59 + try{
  60 + Set<String> cars = dayOfSchedule.findCarByLineCode(lineCode);
  61 + for(String car : cars){
  62 + GpsCacheData.remove(car);
  63 + dayOfSchedule.resetRepairReport(car);
  64 + }
  65 + //清除驾驶员上报数据
  66 + pilotReport.clear(lineCode);
  67 + //清除指令数据 指令数据,直接定时全部清空
  68 + //dayOfDirectives.clear(lineCode);
  69 + }catch (Exception e){
  70 + logger.error("清理 60 和 80出现问题", e);
  71 + }
  72 +
  73 + //重载排班数据
  74 + dayOfSchedule.reloadSch(lineCode, currSchDate, false);
  75 + logger.info(lineCode + "翻班完成, " + currSchDate + " -班次数量:" + dayOfSchedule.findByLineCode(lineCode).size());
  76 + }
  77 + }catch (Exception e){
  78 + logger.error("班次更新失败!! -" + lineCode, e);
  79 + }
  80 + }
  81 +
  82 + //按公司编码索引数据
  83 + dayOfSchedule.groupByGsbm();
  84 +
  85 + //首末班入库(给网关用的数据)
  86 + FirstAndLastHandler.saveAll();
  87 + } catch (Exception e) {
  88 + logger.error("", e);
  89 + }
  90 + logger.warn("班次刷新结束");
  91 + }
  92 +}
src/main/java/com/bsth/service/geo_data/impl/GeoDataServiceImpl.java
@@ -12,8 +12,8 @@ import com.bsth.service.geo_data.impl.dto.CascadeSaveRoad; @@ -12,8 +12,8 @@ import com.bsth.service.geo_data.impl.dto.CascadeSaveRoad;
12 import com.bsth.service.geo_data.impl.dto.CascadeSaveStation; 12 import com.bsth.service.geo_data.impl.dto.CascadeSaveStation;
13 import com.bsth.service.geo_data.impl.dto.SaveRoadRouteDTO; 13 import com.bsth.service.geo_data.impl.dto.SaveRoadRouteDTO;
14 import com.bsth.service.geo_data.impl.dto.SaveStationRouteDTO; 14 import com.bsth.service.geo_data.impl.dto.SaveStationRouteDTO;
15 -import com.bsth.util.GetUIDAndCode;  
16 import com.bsth.util.TransGPS; 15 import com.bsth.util.TransGPS;
  16 +import com.fasterxml.jackson.databind.ObjectMapper;
17 import com.google.common.base.Splitter; 17 import com.google.common.base.Splitter;
18 import org.slf4j.Logger; 18 import org.slf4j.Logger;
19 import org.slf4j.LoggerFactory; 19 import org.slf4j.LoggerFactory;
@@ -21,11 +21,10 @@ import org.springframework.beans.factory.annotation.Autowired; @@ -21,11 +21,10 @@ import org.springframework.beans.factory.annotation.Autowired;
21 import org.springframework.jdbc.core.BatchPreparedStatementSetter; 21 import org.springframework.jdbc.core.BatchPreparedStatementSetter;
22 import org.springframework.jdbc.core.BeanPropertyRowMapper; 22 import org.springframework.jdbc.core.BeanPropertyRowMapper;
23 import org.springframework.jdbc.core.JdbcTemplate; 23 import org.springframework.jdbc.core.JdbcTemplate;
24 -import org.springframework.jdbc.datasource.DataSourceTransactionManager;  
25 import org.springframework.stereotype.Service; 24 import org.springframework.stereotype.Service;
26 -import org.springframework.transaction.TransactionDefinition;  
27 import org.springframework.transaction.TransactionStatus; 25 import org.springframework.transaction.TransactionStatus;
28 -import org.springframework.transaction.support.DefaultTransactionDefinition; 26 +import org.springframework.transaction.support.TransactionCallback;
  27 +import org.springframework.transaction.support.TransactionTemplate;
29 28
30 import java.sql.PreparedStatement; 29 import java.sql.PreparedStatement;
31 import java.sql.SQLException; 30 import java.sql.SQLException;
@@ -47,6 +46,12 @@ public class GeoDataServiceImpl implements GeoDataService { @@ -47,6 +46,12 @@ public class GeoDataServiceImpl implements GeoDataService {
47 @Autowired 46 @Autowired
48 StationRepository stationRepository; 47 StationRepository stationRepository;
49 48
  49 + @Autowired
  50 + private TransactionTemplate transactionTemplate;
  51 +
  52 + @Autowired
  53 + private ObjectMapper mapper;
  54 +
50 Logger logger = LoggerFactory.getLogger(this.getClass()); 55 Logger logger = LoggerFactory.getLogger(this.getClass());
51 56
52 @Override 57 @Override
@@ -172,141 +177,138 @@ public class GeoDataServiceImpl implements GeoDataService { @@ -172,141 +177,138 @@ public class GeoDataServiceImpl implements GeoDataService {
172 public Map<String, Object> updateStationName(Map<String, Object> map) { 177 public Map<String, Object> updateStationName(Map<String, Object> map) {
173 Map<String, Object> rs = new HashMap<>(); 178 Map<String, Object> rs = new HashMap<>();
174 179
175 - //编程式事务  
176 - DataSourceTransactionManager tran = new DataSourceTransactionManager(jdbcTemplate.getDataSource());  
177 - DefaultTransactionDefinition def = new DefaultTransactionDefinition();  
178 - def.setPropagationBehavior(TransactionDefinition.PROPAGATION_REQUIRED);  
179 - TransactionStatus status = tran.getTransaction(def);  
180 - try {  
181 -  
182 - int id = Integer.parseInt(map.get("id").toString());  
183 - String name = map.get("stationName").toString();  
184 - String code = map.get("stationCode").toString();  
185 - String lineCode = map.get("lineCode").toString();  
186 - String versions = map.get("versions").toString();  
187 -  
188 - //更新历史站点路由  
189 - jdbcTemplate.update("update bsth_c_ls_stationroute set station_name=? where id=?", name, id);  
190 - //更新站点  
191 - jdbcTemplate.update("update bsth_c_station set station_name=? where station_cod=?", name, code);  
192 -  
193 - //写一条走向变更记录  
194 - jdbcTemplate.update("insert into logger_route_synchro(t, line_code, version) values(?, ?, ?)", System.currentTimeMillis(), lineCode, versions);  
195 -  
196 - tran.commit(status);  
197 -  
198 - rs.put("station", findOne(id));  
199 - rs.put("status", ResponseCode.SUCCESS);  
200 - } catch (Exception e) {  
201 - tran.rollback(status);  
202 - logger.error("", e);  
203 - rs.put("status", ResponseCode.ERROR);  
204 - rs.put("msg", "服务器出现异常");  
205 - }  
206 - return rs; 180 + return transactionTemplate.execute(new TransactionCallback<Map<String, Object>>() {
  181 + @Override
  182 + public Map<String, Object> doInTransaction(TransactionStatus status) {
  183 + try {
  184 +
  185 + int id = Integer.parseInt(map.get("id").toString());
  186 + String name = map.get("stationName").toString();
  187 + String code = map.get("stationCode").toString();
  188 + String lineCode = map.get("lineCode").toString();
  189 + String versions = map.get("versions").toString();
  190 +
  191 + //更新历史站点路由
  192 + jdbcTemplate.update("update bsth_c_ls_stationroute set station_name=? where id=?", name, id);
  193 + //更新站点
  194 + jdbcTemplate.update("update bsth_c_station set station_name=? where station_cod=?", name, code);
  195 +
  196 + //写一条走向变更记录
  197 + jdbcTemplate.update("insert into logger_route_synchro(t, line_code, version) values(?, ?, ?)", System.currentTimeMillis(), lineCode, versions);
  198 +
  199 + rs.put("station", findOne(id));
  200 + rs.put("status", ResponseCode.SUCCESS);
  201 + } catch (Exception e) {
  202 + status.setRollbackOnly();
  203 + logger.error("", e);
  204 + rs.put("status", ResponseCode.ERROR);
  205 + rs.put("msg", "服务器出现异常");
  206 + }
  207 + return rs;
  208 + }
  209 + });
207 } 210 }
208 211
209 @Override 212 @Override
210 public Map<String, Object> addNewRoadRoute(String lineCode, int upDown, int versions, String sectionName, String crosesRoad, String coords, int prevRouteId) { 213 public Map<String, Object> addNewRoadRoute(String lineCode, int upDown, int versions, String sectionName, String crosesRoad, String coords, int prevRouteId) {
211 Map<String, Object> rs = new HashMap<>(); 214 Map<String, Object> rs = new HashMap<>();
212 215
213 - //编程式事务  
214 - DataSourceTransactionManager tran = new DataSourceTransactionManager(jdbcTemplate.getDataSource());  
215 - DefaultTransactionDefinition def = new DefaultTransactionDefinition();  
216 - def.setPropagationBehavior(TransactionDefinition.PROPAGATION_REQUIRED);  
217 - TransactionStatus status = tran.getTransaction(def);  
218 - try {  
219 - //根据线路编码,查询线路ID  
220 - int lineId = jdbcTemplate.queryForObject("select id from bsth_c_line where line_code=" + lineCode, Integer.class);  
221 -  
222 - String sql = "select * from bsth_c_ls_sectionroute where line_code='" + lineCode + "' and line=" + lineId + " and directions=" + upDown + " and destroy=0 and versions=" + versions;  
223 - List<SaveRoadRouteDTO> routes = jdbcTemplate.query(sql, BeanPropertyRowMapper.newInstance(SaveRoadRouteDTO.class));  
224 -  
225 - Collections.sort(routes, new RoadRouteComp());  
226 -  
227 - long sCode = sectionRepository.sectionMaxId() + 1;  
228 - //转wgs  
229 - String wgsCoord = "LINESTRING(" + bdPolygon2Wgs(coords) + ")";  
230 - String bdCooed = "LINESTRING(" + coords + ")";  
231 - //insert 路段  
232 - sql = "insert into bsth_c_section(id, section_code, section_name, croses_road, bsection_vector, gsection_vector, create_date, update_date, versions) " +  
233 - " values(?,?,?,?,ST_GeomFromText('" + bdCooed + "'),ST_GeomFromText('" + wgsCoord + "'),sysdate(),sysdate(),?)";  
234 -  
235 - jdbcTemplate.update(sql, sCode, sCode, sectionName, crosesRoad, 1);  
236 - 216 + return transactionTemplate.execute(new TransactionCallback<Map<String, Object>>() {
237 217
238 - SaveRoadRouteDTO srr;  
239 - int currentNo = -1,  
240 - no = 100, step = 100;  
241 -  
242 - if (prevRouteId == -1) {  
243 - //起点站  
244 - currentNo = no;  
245 - no += step;  
246 - }  
247 - //重新排序路由  
248 - for (int i = 0, size = routes.size(); i < size; i++) {  
249 - srr = routes.get(i);  
250 - srr.setSectionrouteCode(no += step);  
251 - if (srr.getId().intValue() == prevRouteId) {  
252 - no += step;  
253 - currentNo = no; 218 + @Override
  219 + public Map<String, Object> doInTransaction(TransactionStatus status) {
  220 + try {
  221 + //根据线路编码,查询线路ID
  222 + int lineId = jdbcTemplate.queryForObject("select id from bsth_c_line where line_code=" + lineCode, Integer.class);
  223 +
  224 + String sql = "select * from bsth_c_ls_sectionroute where line_code='" + lineCode + "' and line=" + lineId + " and directions=" + upDown + " and destroy=0 and versions=" + versions;
  225 + List<SaveRoadRouteDTO> routes = jdbcTemplate.query(sql, BeanPropertyRowMapper.newInstance(SaveRoadRouteDTO.class));
  226 +
  227 + Collections.sort(routes, new RoadRouteComp());
  228 +
  229 + long sCode = sectionRepository.sectionMaxId() + 1;
  230 + //转wgs
  231 + String wgsCoord = "LINESTRING(" + bdPolygon2Wgs(coords) + ")";
  232 + String bdCooed = "LINESTRING(" + coords + ")";
  233 + //insert 路段
  234 + sql = "insert into bsth_c_section(id, section_code, section_name, croses_road, bsection_vector, gsection_vector, create_date, update_date, versions) " +
  235 + " values(?,?,?,?,ST_GeomFromText('" + bdCooed + "'),ST_GeomFromText('" + wgsCoord + "'),sysdate(),sysdate(),?)";
  236 +
  237 + jdbcTemplate.update(sql, sCode, sCode, sectionName, crosesRoad, 1);
  238 +
  239 +
  240 + SaveRoadRouteDTO srr;
  241 + int currentNo = -1,
  242 + no = 100, step = 100;
  243 +
  244 + if (prevRouteId == -1) {
  245 + //起点站
  246 + currentNo = no;
  247 + no += step;
  248 + }
  249 + //重新排序路由
  250 + for (int i = 0, size = routes.size(); i < size; i++) {
  251 + srr = routes.get(i);
  252 + srr.setSectionrouteCode(no += step);
  253 + if (srr.getId().intValue() == prevRouteId) {
  254 + no += step;
  255 + currentNo = no;
  256 + }
  257 + }
  258 +
  259 + srr = new SaveRoadRouteDTO();
  260 + srr.setLine(lineId);
  261 + srr.setLineCode(lineCode);
  262 + srr.setDirections(upDown);
  263 + srr.setVersions(versions);
  264 +
  265 + srr.setSectionrouteCode(currentNo);
  266 + srr.setSection(sCode);
  267 + srr.setSectionCode(sCode + "");
  268 + srr.setIsRoadeSpeed(0);
  269 + srr.setDestroy(0);
  270 + Date d = new Date();
  271 + srr.setCreateDate(d);
  272 + srr.setUpdateDate(d);
  273 +
  274 + final List<SaveRoadRouteDTO> saveList = routes;
  275 + //insert 新路由 (ID自增)
  276 + jdbcTemplate.update("insert into bsth_c_ls_sectionroute(line_code, section_code, sectionroute_code, directions, line, section, create_date,update_date,versions,destroy,is_roade_speed)" +
  277 + " values(?,?,?,?,?,?,?,?,?,?,?)", srr.getLineCode(), srr.getSectionCode(), srr.getSectionrouteCode(), srr.getDirections(), srr.getLine(), srr.getSection(), srr.getCreateDate(), srr.getUpdateDate(), versions, srr.getDestroy(), srr.getIsRoadeSpeed());
  278 +
  279 + // update 原路由
  280 + jdbcTemplate.batchUpdate("update bsth_c_ls_sectionroute set sectionroute_code=? where id=?"
  281 + , new BatchPreparedStatementSetter() {
  282 + @Override
  283 + public void setValues(PreparedStatement ps, int i) throws SQLException {
  284 + SaveRoadRouteDTO srr = saveList.get(i);
  285 + ps.setInt(1, srr.getSectionrouteCode());
  286 + ps.setInt(2, srr.getId());
  287 + }
  288 +
  289 + @Override
  290 + public int getBatchSize() {
  291 + return saveList.size();
  292 + }
  293 + });
  294 +
  295 +
  296 + //写一条走向变更记录
  297 + jdbcTemplate.update("insert into logger_route_synchro(t, line_code, version) values(?, ?, ?)", System.currentTimeMillis(), lineCode, versions);
  298 +
  299 + //返回更新之后的数据
  300 + List<GeoRoad> list = findRoadByUpdown(lineCode, upDown, versions);
  301 + rs.put("list", list);
  302 + rs.put("status", ResponseCode.SUCCESS);
  303 + } catch (Exception e) {
  304 + status.setRollbackOnly();
  305 + logger.error("", e);
  306 + rs.put("status", ResponseCode.ERROR);
  307 + rs.put("msg", "服务器出现异常");
254 } 308 }
  309 + return rs;
255 } 310 }
256 -  
257 - srr = new SaveRoadRouteDTO();  
258 - srr.setLine(lineId);  
259 - srr.setLineCode(lineCode);  
260 - srr.setDirections(upDown);  
261 - srr.setVersions(versions);  
262 -  
263 - srr.setSectionrouteCode(currentNo);  
264 - srr.setSection(sCode);  
265 - srr.setSectionCode(sCode + "");  
266 - srr.setIsRoadeSpeed(0);  
267 - srr.setDestroy(0);  
268 - Date d = new Date();  
269 - srr.setCreateDate(d);  
270 - srr.setUpdateDate(d);  
271 -  
272 - final List<SaveRoadRouteDTO> saveList = routes;  
273 - //insert 新路由 (ID自增)  
274 - jdbcTemplate.update("insert into bsth_c_ls_sectionroute(line_code, section_code, sectionroute_code, directions, line, section, create_date,update_date,versions,destroy,is_roade_speed)" +  
275 - " values(?,?,?,?,?,?,?,?,?,?,?)", srr.getLineCode(), srr.getSectionCode(), srr.getSectionrouteCode(), srr.getDirections(), srr.getLine(), srr.getSection(), srr.getCreateDate(), srr.getUpdateDate(), versions, srr.getDestroy(), srr.getIsRoadeSpeed());  
276 -  
277 - // update 原路由  
278 - jdbcTemplate.batchUpdate("update bsth_c_ls_sectionroute set sectionroute_code=? where id=?"  
279 - , new BatchPreparedStatementSetter() {  
280 - @Override  
281 - public void setValues(PreparedStatement ps, int i) throws SQLException {  
282 - SaveRoadRouteDTO srr = saveList.get(i);  
283 - ps.setInt(1, srr.getSectionrouteCode());  
284 - ps.setInt(2, srr.getId());  
285 - }  
286 -  
287 - @Override  
288 - public int getBatchSize() {  
289 - return saveList.size();  
290 - }  
291 - });  
292 -  
293 -  
294 - //写一条走向变更记录  
295 - jdbcTemplate.update("insert into logger_route_synchro(t, line_code, version) values(?, ?, ?)", System.currentTimeMillis(), lineCode, versions);  
296 -  
297 - tran.commit(status);  
298 -  
299 - //返回更新之后的数据  
300 - List<GeoRoad> list = findRoadByUpdown(lineCode, upDown, versions);  
301 - rs.put("list", list);  
302 - rs.put("status", ResponseCode.SUCCESS);  
303 - } catch (Exception e) {  
304 - tran.rollback(status);  
305 - logger.error("", e);  
306 - rs.put("status", ResponseCode.ERROR);  
307 - rs.put("msg", "服务器出现异常");  
308 - }  
309 - return rs; 311 + });
310 } 312 }
311 313
312 /** 314 /**
@@ -339,99 +341,100 @@ public class GeoDataServiceImpl implements GeoDataService { @@ -339,99 +341,100 @@ public class GeoDataServiceImpl implements GeoDataService {
339 public Map<String, Object> addNewLineVersion(Map<String, Object> map) { 341 public Map<String, Object> addNewLineVersion(Map<String, Object> map) {
340 Map<String, Object> rs = new HashMap<>(); 342 Map<String, Object> rs = new HashMap<>();
341 343
342 - //编程式事务  
343 - DataSourceTransactionManager tran = new DataSourceTransactionManager(jdbcTemplate.getDataSource());  
344 - DefaultTransactionDefinition def = new DefaultTransactionDefinition();  
345 - def.setPropagationBehavior(TransactionDefinition.PROPAGATION_REQUIRED);  
346 - TransactionStatus status = tran.getTransaction(def);  
347 - try {  
348 -  
349 - String lineCode = map.get("lineCode").toString();  
350 - String remark = map.get("remark").toString();  
351 - String name = map.get("name").toString();  
352 - Date startDate = new SimpleDateFormat("yyyy-MM-dd HH:mm").parse(map.get("startDate").toString());  
353 - int extendsVersion = Integer.parseInt(map.get("extendsVersion").toString()); 344 + return transactionTemplate.execute(new TransactionCallback<Map<String, Object>>() {
354 345
355 - if(startDate.getTime() - System.currentTimeMillis() < 1000 * 60 * 3){  
356 - rs.put("status", ResponseCode.ERROR);  
357 - rs.put("msg", "启用时间最少需要晚于当前服务器时间3分钟!");  
358 - return rs;  
359 - }  
360 -  
361 - int nameCount = jdbcTemplate.queryForObject("select count(*) from bsth_c_line_versions where line_code=" + lineCode + " and name='"+name+"'", Integer.class);  
362 - if(nameCount > 0){  
363 - rs.put("status", ResponseCode.ERROR);  
364 - rs.put("msg", "你不能使用一个已经存在的版本名称!!");  
365 - return rs;  
366 - }  
367 -  
368 - //当前最大的版本号  
369 - int maxVersion = jdbcTemplate.queryForObject("select max(versions) as versions from bsth_c_line_versions where line_code=" + lineCode, Integer.class);  
370 - Date d = new Date();  
371 -  
372 - //根据线路编码,查询线路ID  
373 - int lineId = jdbcTemplate.queryForObject("select id from bsth_c_line where line_code=" + lineCode, Integer.class);  
374 -  
375 - maxVersion += 1;  
376 - LineVersions lVersion = new LineVersions();  
377 - lVersion.setName(name);  
378 - lVersion.setVersions(maxVersion);  
379 - lVersion.setRemark(remark);  
380 - lVersion.setStartDate(startDate);  
381 - lVersion.setStatus(2);  
382 - lVersion.setCreateDate(d);  
383 - lVersion.setUpdateDate(d);  
384 - lVersion.setLineCode(lineCode);  
385 -  
386 - //如果有待启用的版本,设置为历史版本  
387 - jdbcTemplate.update("update bsth_c_line_versions set `status`=2, start_date=null,end_date=null where line_code='"+lineCode+"' and `status`=0");  
388 -  
389 - //入库线路版本  
390 - jdbcTemplate.update("insert into bsth_c_line_versions(name, line, line_code, versions, start_date, create_date, update_date, remark,status, isupdate) " +  
391 - " values(?,?,?,?,?,?,?,?,?,?)", lVersion.getName(), lineId, lVersion.getLineCode()  
392 - , lVersion.getVersions(), lVersion.getStartDate(), lVersion.getCreateDate(), lVersion.getUpdateDate(), lVersion.getRemark(), lVersion.getStatus(), lVersion.getIsupdate());  
393 -  
394 - if (extendsVersion != -1) {  
395 - //复制站点信息  
396 - String sql = "SELECT t1.id AS route_id,t1.line,t1.directions,t1.station,t1.station_name,t1.station_route_code,t1.line_code,t1.station_code,t1.station_mark,t1.distances,t1.to_time,t2.id AS station_id,t2.db_type,t2.b_jwpoints,t2.g_lonx,t2.g_laty,t2.radius,ST_AsText(t2.g_polygon_grid) as g_polygon_grid,t2.shapes_type FROM bsth_c_ls_stationroute t1 LEFT JOIN bsth_c_station t2 ON t1.station_code = t2.station_cod where t1.destroy=0 and t1.line_code='" + lineCode + "' and t1.versions="+extendsVersion+" order by t1.directions, t1.station_route_code";  
397 - List<CascadeSaveStation> cssList = jdbcTemplate.query(sql, BeanPropertyRowMapper.newInstance(CascadeSaveStation.class));  
398 -  
399 - //新的站点编码  
400 - long sCode;  
401 - for (CascadeSaveStation ss : cssList) {  
402 - sCode = stationRepository.stationMaxId() + 1;  
403 - ss.setRouteId(null);  
404 - ss.setStationCode(sCode + "");  
405 - ss.setStation((int) sCode);  
406 - }  
407 - //入库新版本的站点 和 路由  
408 - batchInsertStation(cssList, maxVersion);  
409 -  
410 - //复制路段信息  
411 - sql = "SELECT t1.id AS route_id,t1.line,t1.line_code,t1.directions,t1.section,t1.section_code,t1.sectionroute_code,t1.versions,t2.section_name,t2.croses_road,ST_AsText(t2.gsection_vector) as gsection_vector,t2.db_type,t2.speed_limit FROM bsth_c_ls_sectionroute t1 LEFT JOIN bsth_c_section t2 ON t1.section_code = t2.section_code WHERE t1.destroy = 0 AND t1.line_code = '"+lineCode+"' and t1.versions="+ extendsVersion +" ORDER BY t1.directions,t1.sectionroute_code";  
412 - List<CascadeSaveRoad> csrList = jdbcTemplate.query(sql, BeanPropertyRowMapper.newInstance(CascadeSaveRoad.class));  
413 - //新的路段编码  
414 - long cCode;  
415 - for(CascadeSaveRoad csr : csrList){  
416 - cCode = sectionRepository.sectionMaxId() + 1;  
417 - csr.setRouteId(null);  
418 - csr.setSection((int) cCode);  
419 - csr.setSectionCode(cCode + ""); 346 + @Override
  347 + public Map<String, Object> doInTransaction(TransactionStatus status) {
  348 + try {
  349 +
  350 + String lineCode = map.get("lineCode").toString();
  351 + String remark = map.get("remark").toString();
  352 + String name = map.get("name").toString();
  353 + Date startDate = new SimpleDateFormat("yyyy-MM-dd HH:mm").parse(map.get("startDate").toString());
  354 + int extendsVersion = Integer.parseInt(map.get("extendsVersion").toString());
  355 +
  356 + if(startDate.getTime() - System.currentTimeMillis() < 1000 * 60 * 3){
  357 + rs.put("status", ResponseCode.ERROR);
  358 + rs.put("msg", "启用时间最少需要晚于当前服务器时间3分钟!");
  359 + return rs;
  360 + }
  361 +
  362 + int nameCount = jdbcTemplate.queryForObject("select count(*) from bsth_c_line_versions where line_code=" + lineCode + " and name='"+name+"'", Integer.class);
  363 + if(nameCount > 0){
  364 + rs.put("status", ResponseCode.ERROR);
  365 + rs.put("msg", "你不能使用一个已经存在的版本名称!!");
  366 + return rs;
  367 + }
  368 +
  369 + //当前最大的版本号
  370 + int maxVersion = jdbcTemplate.queryForObject("select max(versions) as versions from bsth_c_line_versions where line_code=" + lineCode, Integer.class);
  371 + Date d = new Date();
  372 +
  373 + //根据线路编码,查询线路ID
  374 + int lineId = jdbcTemplate.queryForObject("select id from bsth_c_line where line_code=" + lineCode, Integer.class);
  375 +
  376 + maxVersion += 1;
  377 + LineVersions lVersion = new LineVersions();
  378 + lVersion.setName(name);
  379 + lVersion.setVersions(maxVersion);
  380 + lVersion.setRemark(remark);
  381 + lVersion.setStartDate(startDate);
  382 + lVersion.setStatus(2);
  383 + lVersion.setCreateDate(d);
  384 + lVersion.setUpdateDate(d);
  385 + lVersion.setLineCode(lineCode);
  386 +
  387 + //如果有待启用的版本,设置为历史版本
  388 + jdbcTemplate.update("update bsth_c_line_versions set `status`=2, start_date=null,end_date=null where line_code='"+lineCode+"' and `status`=0");
  389 +
  390 + //入库线路版本
  391 + jdbcTemplate.update("insert into bsth_c_line_versions(name, line, line_code, versions, start_date, create_date, update_date, remark,status, isupdate) " +
  392 + " values(?,?,?,?,?,?,?,?,?,?)", lVersion.getName(), lineId, lVersion.getLineCode()
  393 + , lVersion.getVersions(), lVersion.getStartDate(), lVersion.getCreateDate(), lVersion.getUpdateDate(), lVersion.getRemark(), lVersion.getStatus(), lVersion.getIsupdate());
  394 +
  395 + if (extendsVersion != -1) {
  396 + //复制站点信息
  397 + String sql = "SELECT t1.id AS route_id,t1.line,t1.directions,t1.station,t1.station_name,t1.station_route_code,t1.line_code,t1.station_code,t1.station_mark,t1.distances,t1.to_time,t2.id AS station_id,t2.db_type,t2.b_jwpoints,t2.g_lonx,t2.g_laty,t2.radius,ST_AsText(t2.g_polygon_grid) as g_polygon_grid,t2.shapes_type FROM bsth_c_ls_stationroute t1 LEFT JOIN bsth_c_station t2 ON t1.station_code = t2.station_cod where t1.destroy=0 and t1.line_code='" + lineCode + "' and t1.versions="+extendsVersion+" order by t1.directions, t1.station_route_code";
  398 + List<CascadeSaveStation> cssList = jdbcTemplate.query(sql, BeanPropertyRowMapper.newInstance(CascadeSaveStation.class));
  399 +
  400 + //新的站点编码
  401 + long sCode;
  402 + for (CascadeSaveStation ss : cssList) {
  403 + sCode = stationRepository.stationMaxId() + 1;
  404 + ss.setRouteId(null);
  405 + ss.setStationCode(sCode + "");
  406 + ss.setStation((int) sCode);
  407 + }
  408 + //入库新版本的站点 和 路由
  409 + batchInsertStation(cssList, maxVersion);
  410 +
  411 + //复制路段信息
  412 + sql = "SELECT t1.id AS route_id,t1.line,t1.line_code,t1.directions,t1.section,t1.section_code,t1.sectionroute_code,t1.versions,t2.section_name,t2.croses_road,ST_AsText(t2.gsection_vector) as gsection_vector,t2.db_type,t2.speed_limit FROM bsth_c_ls_sectionroute t1 LEFT JOIN bsth_c_section t2 ON t1.section_code = t2.section_code WHERE t1.destroy = 0 AND t1.line_code = '"+lineCode+"' and t1.versions="+ extendsVersion +" ORDER BY t1.directions,t1.sectionroute_code";
  413 + List<CascadeSaveRoad> csrList = jdbcTemplate.query(sql, BeanPropertyRowMapper.newInstance(CascadeSaveRoad.class));
  414 + //新的路段编码
  415 + long cCode;
  416 + for(CascadeSaveRoad csr : csrList){
  417 + cCode = sectionRepository.sectionMaxId() + 1;
  418 + csr.setRouteId(null);
  419 + csr.setSection((int) cCode);
  420 + csr.setSectionCode(cCode + "");
  421 + }
  422 + //入库新版本的路段 和 路段路由
  423 + batchInsertRoad(csrList, maxVersion);
  424 + }
  425 +
  426 + rs.put("newVersion", maxVersion);
  427 + rs.put("status", ResponseCode.SUCCESS);
  428 + } catch (Exception e) {
  429 + status.setRollbackOnly();
  430 + logger.error("", e);
  431 + rs.put("status", ResponseCode.ERROR);
  432 + rs.put("msg", "服务器出现异常");
420 } 433 }
421 - //入库新版本的路段 和 路段路由  
422 - batchInsertRoad(csrList, maxVersion); 434 + return rs;
423 } 435 }
  436 + });
424 437
425 - tran.commit(status);  
426 - rs.put("newVersion", maxVersion);  
427 - rs.put("status", ResponseCode.SUCCESS);  
428 - } catch (Exception e) {  
429 - tran.rollback(status);  
430 - logger.error("", e);  
431 - rs.put("status", ResponseCode.ERROR);  
432 - rs.put("msg", "服务器出现异常");  
433 - }  
434 - return rs;  
435 } 438 }
436 439
437 /** 440 /**
@@ -444,19 +447,17 @@ public class GeoDataServiceImpl implements GeoDataService { @@ -444,19 +447,17 @@ public class GeoDataServiceImpl implements GeoDataService {
444 public Map<String, Object> deleteLineVersion(String lineCode, int version) { 447 public Map<String, Object> deleteLineVersion(String lineCode, int version) {
445 Map<String, Object> rs = new HashMap<>(); 448 Map<String, Object> rs = new HashMap<>();
446 449
447 - //编程式事务  
448 - DataSourceTransactionManager tran = new DataSourceTransactionManager(jdbcTemplate.getDataSource());  
449 - DefaultTransactionDefinition def = new DefaultTransactionDefinition();  
450 - def.setPropagationBehavior(TransactionDefinition.PROPAGATION_REQUIRED);  
451 - TransactionStatus status = tran.getTransaction(def);  
452 - try{  
453 - int enableVersion = jdbcTemplate.queryForObject("select versions from bsth_c_line_versions where line_code='"+lineCode+"' and `status`=1", Integer.class);  
454 -  
455 - if(enableVersion==version){  
456 - rs.put("status", ResponseCode.ERROR);  
457 - rs.put("msg", "你不能删除当前正在启用的走向版本!");  
458 - return rs;  
459 - } 450 + return transactionTemplate.execute(new TransactionCallback<Map<String, Object>>() {
  451 + @Override
  452 + public Map<String, Object> doInTransaction(TransactionStatus status) {
  453 + try{
  454 + int enableVersion = jdbcTemplate.queryForObject("select versions from bsth_c_line_versions where line_code='"+lineCode+"' and `status`=1", Integer.class);
  455 +
  456 + if(enableVersion==version){
  457 + rs.put("status", ResponseCode.ERROR);
  458 + rs.put("msg", "你不能删除当前正在启用的走向版本!");
  459 + return rs;
  460 + }
460 /*int versionCount = jdbcTemplate.queryForObject("select count(*) from bsth_c_line_versions where line_code='"+lineCode+"'", Integer.class); 461 /*int versionCount = jdbcTemplate.queryForObject("select count(*) from bsth_c_line_versions where line_code='"+lineCode+"'", Integer.class);
461 if(versionCount == 1){ 462 if(versionCount == 1){
462 rs.put("status", ResponseCode.ERROR); 463 rs.put("status", ResponseCode.ERROR);
@@ -472,27 +473,29 @@ public class GeoDataServiceImpl implements GeoDataService { @@ -472,27 +473,29 @@ public class GeoDataServiceImpl implements GeoDataService {
472 473
473 List<Integer> stationRemoves = jdbcTemplate.queryForList(sql, Integer.class);*/ 474 List<Integer> stationRemoves = jdbcTemplate.queryForList(sql, Integer.class);*/
474 475
475 - //删除站点路由  
476 - String sql = "delete from bsth_c_ls_stationroute where line_code='"+lineCode+"' and versions=" + version;  
477 - jdbcTemplate.update(sql); 476 + //删除站点路由
  477 + String sql = "delete from bsth_c_ls_stationroute where line_code='"+lineCode+"' and versions=" + version;
  478 + jdbcTemplate.update(sql);
478 479
479 - //删除路段路由  
480 - sql = "delete from bsth_c_ls_sectionroute where line_code='"+lineCode+"' and versions=" + version;  
481 - jdbcTemplate.update(sql); 480 + //删除路段路由
  481 + sql = "delete from bsth_c_ls_sectionroute where line_code='"+lineCode+"' and versions=" + version;
  482 + jdbcTemplate.update(sql);
482 483
483 - //删除版本信息  
484 - sql = "delete from bsth_c_line_versions where line_code='"+lineCode+"' and versions=" + version;  
485 - jdbcTemplate.update(sql); 484 + //删除版本信息
  485 + sql = "delete from bsth_c_line_versions where line_code='"+lineCode+"' and versions=" + version;
  486 + jdbcTemplate.update(sql);
  487 +
  488 + rs.put("status", ResponseCode.SUCCESS);
  489 + }catch (Exception e){
  490 + status.setRollbackOnly();
  491 + logger.error("", e);
  492 + rs.put("status", ResponseCode.ERROR);
  493 + rs.put("msg", "服务器出现异常");
  494 + }
  495 + return rs;
  496 + }
  497 + });
486 498
487 - tran.commit(status);  
488 - rs.put("status", ResponseCode.SUCCESS);  
489 - }catch (Exception e){  
490 - tran.rollback(status);  
491 - logger.error("", e);  
492 - rs.put("status", ResponseCode.ERROR);  
493 - rs.put("msg", "服务器出现异常");  
494 - }  
495 - return rs;  
496 } 499 }
497 500
498 /** 501 /**
@@ -541,7 +544,7 @@ public class GeoDataServiceImpl implements GeoDataService { @@ -541,7 +544,7 @@ public class GeoDataServiceImpl implements GeoDataService {
541 544
542 /** 545 /**
543 * 批量入库路段 546 * 批量入库路段
544 - * @param cssList 547 + * @param csrList
545 * @param version 548 * @param version
546 */ 549 */
547 private void batchInsertRoad(final List<CascadeSaveRoad> csrList, final int version){ 550 private void batchInsertRoad(final List<CascadeSaveRoad> csrList, final int version){
@@ -659,145 +662,144 @@ public class GeoDataServiceImpl implements GeoDataService { @@ -659,145 +662,144 @@ public class GeoDataServiceImpl implements GeoDataService {
659 public Map<String, Object> addNewStationRoute(String lineCode, int upDown, int versions, String stationName, Float lat, Float lng, int prevRouteId) { 662 public Map<String, Object> addNewStationRoute(String lineCode, int upDown, int versions, String stationName, Float lat, Float lng, int prevRouteId) {
660 Map<String, Object> rs = new HashMap<>(); 663 Map<String, Object> rs = new HashMap<>();
661 664
662 - //编程式事务  
663 - DataSourceTransactionManager tran = new DataSourceTransactionManager(jdbcTemplate.getDataSource());  
664 - DefaultTransactionDefinition def = new DefaultTransactionDefinition();  
665 - def.setPropagationBehavior(TransactionDefinition.PROPAGATION_REQUIRED);  
666 - TransactionStatus status = tran.getTransaction(def);  
667 - try {  
668 - //根据线路编码,查询线路ID  
669 - int lineId = jdbcTemplate.queryForObject("select id from bsth_c_line where line_code=" + lineCode, Integer.class); 665 + return transactionTemplate.execute(new TransactionCallback<Map<String, Object>>() {
  666 + @Override
  667 + public Map<String, Object> doInTransaction(TransactionStatus status) {
  668 + try {
  669 + //根据线路编码,查询线路ID
  670 + int lineId = jdbcTemplate.queryForObject("select id from bsth_c_line where line_code=" + lineCode, Integer.class);
670 671
671 - String sql = "select * from bsth_c_ls_stationroute where line_code='" + lineCode + "' and line=" + lineId + " and directions=" + upDown + " and destroy=0 and versions=" + versions;  
672 - List<SaveStationRouteDTO> routes = jdbcTemplate.query(sql, BeanPropertyRowMapper.newInstance(SaveStationRouteDTO.class)); 672 + String sql = "select * from bsth_c_ls_stationroute where line_code='" + lineCode + "' and line=" + lineId + " and directions=" + upDown + " and destroy=0 and versions=" + versions;
  673 + List<SaveStationRouteDTO> routes = jdbcTemplate.query(sql, BeanPropertyRowMapper.newInstance(SaveStationRouteDTO.class));
673 674
674 - for (SaveStationRouteDTO s : routes) {  
675 - if (s.getStationName().equals(stationName)) { 675 + for (SaveStationRouteDTO s : routes) {
  676 + if (s.getStationName().equals(stationName)) {
676 677
  678 + rs.put("status", ResponseCode.ERROR);
  679 + rs.put("msg", "重复的站点路由名称!");
  680 + return rs;
  681 + }
  682 + }
  683 + //按路由顺序排列
  684 + Collections.sort(routes, new StationRouteComp());
  685 +
  686 + //转WGS
  687 + TransGPS.Location wgsLoc = TransGPS.transformFromGCJToWGS(TransGPS.bd_decrypt(TransGPS.LocationMake(Double.parseDouble(String.valueOf(lng)), Double.parseDouble(String.valueOf(lat)))));
  688 +
  689 + //insert 站点
  690 + long sCode = stationRepository.stationMaxId() + 1;
  691 + jdbcTemplate.update("insert into bsth_c_station(id, station_cod, station_name, db_type, b_jwpoints, g_lonx, g_laty, destroy, radius, shapes_type, versions) " +
  692 + " values(?,?,?,?,?,?,?,?,?,?,?)", sCode, sCode, stationName, "b", lng + " " + lat, wgsLoc.getLng(), wgsLoc.getLat(), 0, 88, "r", 1);
  693 +
  694 +
  695 + SaveStationRouteDTO sr;
  696 + int currentNo = -1,
  697 + no = 100, step = 100;
  698 +
  699 + if (prevRouteId == -1) {
  700 + //起点站
  701 + currentNo = no;
  702 + no += step;
  703 + }
  704 + //重新排序路由
  705 + for (int i = 0, size = routes.size(); i < size; i++) {
  706 + sr = routes.get(i);
  707 + sr.setStationRouteCode(no);
  708 + no += step;
  709 + if (sr.getId().intValue() == prevRouteId) {
  710 + currentNo = no;
  711 + no += step;
  712 + }
  713 + }
  714 +
  715 + SaveStationRouteDTO nsr = new SaveStationRouteDTO();
  716 + nsr.setLine(lineId);
  717 + nsr.setLineCode(lineCode);
  718 + nsr.setDirections(upDown);
  719 + nsr.setVersions(versions);
  720 + nsr.setStationRouteCode(currentNo);
  721 + nsr.setStation(sCode);
  722 + nsr.setStationCode(sCode + "");
  723 + nsr.setStationName(stationName);
  724 + nsr.setDistances(0d);
  725 + nsr.setToTime(0d);
  726 + Date d = new Date();
  727 + nsr.setCreateDate(d);
  728 + nsr.setUpdateDate(d);
  729 + nsr.setDestroy(0);
  730 + if (prevRouteId == -1)
  731 + nsr.setStationMark("B");
  732 + else if(routes.size()==1)
  733 + nsr.setStationMark("E");
  734 +
  735 + //routes.add(sr);
  736 +
  737 + //重新标记mark
  738 + Collections.sort(routes, new StationRouteComp());
  739 + for (int i = 0, size = routes.size(); i < size; i++) {
  740 + routes.get(i).setStationMark("Z");
  741 + }
  742 + if(routes.size() > 0 && prevRouteId!=-1)
  743 + routes.get(0).setStationMark("B");
  744 + if(routes.size() > 1)
  745 + routes.get(routes.size() - 1).setStationMark("E");
  746 +
  747 + final List<SaveStationRouteDTO> saveList = routes;
  748 + //insert 新路由 (ID自增)
  749 + jdbcTemplate.update("insert into bsth_c_ls_stationroute(line, station, station_name, station_route_code, line_code, station_code, station_mark, distances, to_time, destroy, versions, create_date, update_date,directions) values(?,?,?,?,?,?,?,?,?,?,?,?,?,?)"
  750 + , nsr.getLine(), nsr.getStation(), nsr.getStationName(), nsr.getStationRouteCode(), nsr.getLineCode(), nsr.getStationCode(), nsr.getStationMark()
  751 + , nsr.getDistances(), nsr.getToTime(), nsr.getDestroy(), nsr.getVersions(), nsr.getCreateDate(), nsr.getUpdateDate(), nsr.getDirections());
  752 +
  753 + // update 原路由
  754 + jdbcTemplate.batchUpdate("update bsth_c_ls_stationroute set line=?,station=?,station_name=?,station_route_code=?," +
  755 + "line_code=?,station_code=?,station_mark=?,distances=?,to_time=?,destroy=?,versions=?,create_date=?,update_date=?,directions=?" +
  756 + " where id=?"
  757 + , new BatchPreparedStatementSetter() {
  758 + @Override
  759 + public void setValues(PreparedStatement ps, int i) throws SQLException {
  760 + SaveStationRouteDTO sr = saveList.get(i);
  761 + ps.setInt(1, sr.getLine());
  762 + ps.setLong(2, sr.getStation());
  763 + ps.setString(3, sr.getStationName());
  764 + ps.setInt(4, sr.getStationRouteCode());
  765 + ps.setString(5, sr.getLineCode());
  766 + ps.setString(6, sr.getStationCode());
  767 + ps.setString(7, sr.getStationMark());
  768 + ps.setDouble(8, sr.getDistances());
  769 + ps.setDouble(9, sr.getToTime());
  770 + ps.setInt(10, sr.getDestroy());
  771 + ps.setInt(11, sr.getVersions());
  772 + ps.setTimestamp(12, new java.sql.Timestamp(sr.getCreateDate().getTime()));
  773 + ps.setTimestamp(13, new java.sql.Timestamp(sr.getUpdateDate().getTime()));
  774 + ps.setInt(14, sr.getDirections());
  775 + ps.setInt(15, sr.getId());
  776 + }
  777 +
  778 + @Override
  779 + public int getBatchSize() {
  780 + return saveList.size();
  781 + }
  782 + });
  783 +
  784 + //写一条走向变更记录
  785 + jdbcTemplate.update("insert into logger_route_synchro(t, line_code, version) values(?, ?, ?)", System.currentTimeMillis(), lineCode, versions);
  786 +
  787 + //返回更新之后的数据
  788 + List<GeoStation> list = findByUpdown(lineCode, upDown, versions);
  789 +
  790 + rs.put("list", list);
  791 + rs.put("newStationRouteCode", currentNo);
  792 + rs.put("status", ResponseCode.SUCCESS);
  793 + } catch (Exception e) {
  794 + status.setRollbackOnly();
  795 + logger.error("", e);
677 rs.put("status", ResponseCode.ERROR); 796 rs.put("status", ResponseCode.ERROR);
678 - rs.put("msg", "重复的站点路由名称!");  
679 - return rs; 797 + rs.put("msg", "服务器出现异常");
680 } 798 }
  799 + return rs;
681 } 800 }
682 - //按路由顺序排列  
683 - Collections.sort(routes, new StationRouteComp());  
684 -  
685 - //转WGS  
686 - TransGPS.Location wgsLoc = TransGPS.transformFromGCJToWGS(TransGPS.bd_decrypt(TransGPS.LocationMake(Double.parseDouble(String.valueOf(lng)), Double.parseDouble(String.valueOf(lat)))));  
687 -  
688 - //insert 站点  
689 - long sCode = stationRepository.stationMaxId() + 1;  
690 - jdbcTemplate.update("insert into bsth_c_station(id, station_cod, station_name, db_type, b_jwpoints, g_lonx, g_laty, destroy, radius, shapes_type, versions) " +  
691 - " values(?,?,?,?,?,?,?,?,?,?,?)", sCode, sCode, stationName, "b", lng + " " + lat, wgsLoc.getLng(), wgsLoc.getLat(), 0, 88, "r", 1);  
692 -  
693 -  
694 - SaveStationRouteDTO sr;  
695 - int currentNo = -1,  
696 - no = 100, step = 100;  
697 -  
698 - if (prevRouteId == -1) {  
699 - //起点站  
700 - currentNo = no;  
701 - no += step;  
702 - }  
703 - //重新排序路由  
704 - for (int i = 0, size = routes.size(); i < size; i++) {  
705 - sr = routes.get(i);  
706 - sr.setStationRouteCode(no);  
707 - no += step;  
708 - if (sr.getId().intValue() == prevRouteId) {  
709 - currentNo = no;  
710 - no += step;  
711 - }  
712 - }  
713 -  
714 - SaveStationRouteDTO nsr = new SaveStationRouteDTO();  
715 - nsr.setLine(lineId);  
716 - nsr.setLineCode(lineCode);  
717 - nsr.setDirections(upDown);  
718 - nsr.setVersions(versions);  
719 - nsr.setStationRouteCode(currentNo);  
720 - nsr.setStation(sCode);  
721 - nsr.setStationCode(sCode + "");  
722 - nsr.setStationName(stationName);  
723 - nsr.setDistances(0d);  
724 - nsr.setToTime(0d);  
725 - Date d = new Date();  
726 - nsr.setCreateDate(d);  
727 - nsr.setUpdateDate(d);  
728 - nsr.setDestroy(0);  
729 - if (prevRouteId == -1)  
730 - nsr.setStationMark("B");  
731 - else if(routes.size()==1)  
732 - nsr.setStationMark("E");  
733 -  
734 - //routes.add(sr);  
735 -  
736 - //重新标记mark  
737 - Collections.sort(routes, new StationRouteComp());  
738 - for (int i = 0, size = routes.size(); i < size; i++) {  
739 - routes.get(i).setStationMark("Z");  
740 - }  
741 - if(routes.size() > 0 && prevRouteId!=-1)  
742 - routes.get(0).setStationMark("B");  
743 - if(routes.size() > 1)  
744 - routes.get(routes.size() - 1).setStationMark("E");  
745 -  
746 - final List<SaveStationRouteDTO> saveList = routes;  
747 - //insert 新路由 (ID自增)  
748 - jdbcTemplate.update("insert into bsth_c_ls_stationroute(line, station, station_name, station_route_code, line_code, station_code, station_mark, distances, to_time, destroy, versions, create_date, update_date,directions) values(?,?,?,?,?,?,?,?,?,?,?,?,?,?)"  
749 - , nsr.getLine(), nsr.getStation(), nsr.getStationName(), nsr.getStationRouteCode(), nsr.getLineCode(), nsr.getStationCode(), nsr.getStationMark()  
750 - , nsr.getDistances(), nsr.getToTime(), nsr.getDestroy(), nsr.getVersions(), nsr.getCreateDate(), nsr.getUpdateDate(), nsr.getDirections());  
751 -  
752 - // update 原路由  
753 - jdbcTemplate.batchUpdate("update bsth_c_ls_stationroute set line=?,station=?,station_name=?,station_route_code=?," +  
754 - "line_code=?,station_code=?,station_mark=?,distances=?,to_time=?,destroy=?,versions=?,create_date=?,update_date=?,directions=?" +  
755 - " where id=?"  
756 - , new BatchPreparedStatementSetter() {  
757 - @Override  
758 - public void setValues(PreparedStatement ps, int i) throws SQLException {  
759 - SaveStationRouteDTO sr = saveList.get(i);  
760 - ps.setInt(1, sr.getLine());  
761 - ps.setLong(2, sr.getStation());  
762 - ps.setString(3, sr.getStationName());  
763 - ps.setInt(4, sr.getStationRouteCode());  
764 - ps.setString(5, sr.getLineCode());  
765 - ps.setString(6, sr.getStationCode());  
766 - ps.setString(7, sr.getStationMark());  
767 - ps.setDouble(8, sr.getDistances());  
768 - ps.setDouble(9, sr.getToTime());  
769 - ps.setInt(10, sr.getDestroy());  
770 - ps.setInt(11, sr.getVersions());  
771 - ps.setTimestamp(12, new java.sql.Timestamp(sr.getCreateDate().getTime()));  
772 - ps.setTimestamp(13, new java.sql.Timestamp(sr.getUpdateDate().getTime()));  
773 - ps.setInt(14, sr.getDirections());  
774 - ps.setInt(15, sr.getId());  
775 - }  
776 -  
777 - @Override  
778 - public int getBatchSize() {  
779 - return saveList.size();  
780 - }  
781 - });  
782 -  
783 - //写一条走向变更记录  
784 - jdbcTemplate.update("insert into logger_route_synchro(t, line_code, version) values(?, ?, ?)", System.currentTimeMillis(), lineCode, versions);  
785 -  
786 - tran.commit(status);  
787 -  
788 - //返回更新之后的数据  
789 - List<GeoStation> list = findByUpdown(lineCode, upDown, versions); 801 + });
790 802
791 - rs.put("list", list);  
792 - rs.put("newStationRouteCode", currentNo);  
793 - rs.put("status", ResponseCode.SUCCESS);  
794 - } catch (Exception e) {  
795 - tran.rollback(status);  
796 - logger.error("", e);  
797 - rs.put("status", ResponseCode.ERROR);  
798 - rs.put("msg", "服务器出现异常");  
799 - }  
800 - return rs;  
801 } 803 }
802 804
803 private List<GeoStation> findByUpdown(String lineCode, int upDown, int versions) { 805 private List<GeoStation> findByUpdown(String lineCode, int upDown, int versions) {
@@ -827,87 +829,86 @@ public class GeoDataServiceImpl implements GeoDataService { @@ -827,87 +829,86 @@ public class GeoDataServiceImpl implements GeoDataService {
827 public Map<String, Object> destroyStation(GeoStation station) { 829 public Map<String, Object> destroyStation(GeoStation station) {
828 Map<String, Object> rs = new HashMap<>(); 830 Map<String, Object> rs = new HashMap<>();
829 831
830 - //编程式事务  
831 - DataSourceTransactionManager tran = new DataSourceTransactionManager(jdbcTemplate.getDataSource());  
832 - DefaultTransactionDefinition def = new DefaultTransactionDefinition();  
833 - def.setPropagationBehavior(TransactionDefinition.PROPAGATION_REQUIRED);  
834 - TransactionStatus status = tran.getTransaction(def);  
835 - try {  
836 - String sql = "update bsth_c_ls_stationroute set destroy=1 where id=?";  
837 - jdbcTemplate.update(sql, station.getId());  
838 -  
839 - /**  
840 - * ########## 重新排序路由,标记mark #########  
841 - */  
842 - sql = "select * from bsth_c_ls_stationroute where line_code='" + station.getLineCode() + "' and directions=" + station.getDirections() + " and destroy=0 and versions=" + station.getVersions();  
843 - List<SaveStationRouteDTO> routes = jdbcTemplate.query(sql, BeanPropertyRowMapper.newInstance(SaveStationRouteDTO.class));  
844 - Collections.sort(routes, new StationRouteComp());  
845 -  
846 - int no = 0,  
847 - step = 100;  
848 - SaveStationRouteDTO sr;  
849 - //重新排序路由  
850 - for (int i = 0, size = routes.size(); i < size; i++) {  
851 - sr = routes.get(i);  
852 - sr.setStationRouteCode(no += step);  
853 - }  
854 -  
855 - for (int i = 0, size = routes.size(); i < size; i++) {  
856 - routes.get(i).setStationMark("Z"); 832 + return transactionTemplate.execute(new TransactionCallback<Map<String, Object>>() {
  833 + @Override
  834 + public Map<String, Object> doInTransaction(TransactionStatus status) {
  835 + try {
  836 + String sql = "update bsth_c_ls_stationroute set destroy=1 where id=?";
  837 + jdbcTemplate.update(sql, station.getId());
  838 +
  839 + /**
  840 + * ########## 重新排序路由,标记mark #########
  841 + */
  842 + sql = "select * from bsth_c_ls_stationroute where line_code='" + station.getLineCode() + "' and directions=" + station.getDirections() + " and destroy=0 and versions=" + station.getVersions();
  843 + List<SaveStationRouteDTO> routes = jdbcTemplate.query(sql, BeanPropertyRowMapper.newInstance(SaveStationRouteDTO.class));
  844 + Collections.sort(routes, new StationRouteComp());
  845 +
  846 + int no = 0,
  847 + step = 100;
  848 + SaveStationRouteDTO sr;
  849 + //重新排序路由
  850 + for (int i = 0, size = routes.size(); i < size; i++) {
  851 + sr = routes.get(i);
  852 + sr.setStationRouteCode(no += step);
  853 + }
  854 +
  855 + for (int i = 0, size = routes.size(); i < size; i++) {
  856 + routes.get(i).setStationMark("Z");
  857 + }
  858 + if(routes.size() > 0)
  859 + routes.get(0).setStationMark("B");
  860 + if(routes.size() > 1)
  861 + routes.get(routes.size() - 1).setStationMark("E");
  862 +
  863 + final List<SaveStationRouteDTO> saveList = routes;
  864 + // update 原路由
  865 + jdbcTemplate.batchUpdate("update bsth_c_ls_stationroute set line=?,station=?,station_name=?,station_route_code=?," +
  866 + "line_code=?,station_code=?,station_mark=?,distances=?,to_time=?,destroy=?,versions=?,create_date=?,update_date=?,directions=?" +
  867 + " where id=?"
  868 + , new BatchPreparedStatementSetter() {
  869 + @Override
  870 + public void setValues(PreparedStatement ps, int i) throws SQLException {
  871 + SaveStationRouteDTO sr = saveList.get(i);
  872 + ps.setInt(1, sr.getLine());
  873 + ps.setLong(2, sr.getStation());
  874 + ps.setString(3, sr.getStationName());
  875 + ps.setInt(4, sr.getStationRouteCode());
  876 + ps.setString(5, sr.getLineCode());
  877 + ps.setString(6, sr.getStationCode());
  878 + ps.setString(7, sr.getStationMark());
  879 + ps.setDouble(8, sr.getDistances());
  880 + ps.setDouble(9, sr.getToTime());
  881 + ps.setInt(10, sr.getDestroy());
  882 + ps.setInt(11, sr.getVersions());
  883 + ps.setTimestamp(12, new java.sql.Timestamp(sr.getCreateDate().getTime()));
  884 + ps.setTimestamp(13, new java.sql.Timestamp(sr.getUpdateDate().getTime()));
  885 + ps.setInt(14, sr.getDirections());
  886 + ps.setInt(15, sr.getId());
  887 + }
  888 +
  889 + @Override
  890 + public int getBatchSize() {
  891 + return saveList.size();
  892 + }
  893 + });
  894 +
  895 + //写一条走向变更记录
  896 + jdbcTemplate.update("insert into logger_route_synchro(t, line_code, version) values(?, ?, ?)", System.currentTimeMillis(), station.getLineCode(), station.getVersions());
  897 +
  898 + //返回更新之后的数据
  899 + List<GeoStation> list = findByUpdown(station.getLineCode(), station.getDirections(), station.getVersions());
  900 + rs.put("list", list);
  901 + rs.put("status", ResponseCode.SUCCESS);
  902 + } catch (Exception e) {
  903 + status.setRollbackOnly();
  904 + logger.error("", e);
  905 + rs.put("status", ResponseCode.ERROR);
  906 + rs.put("msg", "服务器出现异常");
  907 + }
  908 + return rs;
857 } 909 }
858 - if(routes.size() > 0)  
859 - routes.get(0).setStationMark("B");  
860 - if(routes.size() > 1)  
861 - routes.get(routes.size() - 1).setStationMark("E");  
862 -  
863 - final List<SaveStationRouteDTO> saveList = routes;  
864 - // update 原路由  
865 - jdbcTemplate.batchUpdate("update bsth_c_ls_stationroute set line=?,station=?,station_name=?,station_route_code=?," +  
866 - "line_code=?,station_code=?,station_mark=?,distances=?,to_time=?,destroy=?,versions=?,create_date=?,update_date=?,directions=?" +  
867 - " where id=?"  
868 - , new BatchPreparedStatementSetter() {  
869 - @Override  
870 - public void setValues(PreparedStatement ps, int i) throws SQLException {  
871 - SaveStationRouteDTO sr = saveList.get(i);  
872 - ps.setInt(1, sr.getLine());  
873 - ps.setLong(2, sr.getStation());  
874 - ps.setString(3, sr.getStationName());  
875 - ps.setInt(4, sr.getStationRouteCode());  
876 - ps.setString(5, sr.getLineCode());  
877 - ps.setString(6, sr.getStationCode());  
878 - ps.setString(7, sr.getStationMark());  
879 - ps.setDouble(8, sr.getDistances());  
880 - ps.setDouble(9, sr.getToTime());  
881 - ps.setInt(10, sr.getDestroy());  
882 - ps.setInt(11, sr.getVersions());  
883 - ps.setTimestamp(12, new java.sql.Timestamp(sr.getCreateDate().getTime()));  
884 - ps.setTimestamp(13, new java.sql.Timestamp(sr.getUpdateDate().getTime()));  
885 - ps.setInt(14, sr.getDirections());  
886 - ps.setInt(15, sr.getId());  
887 - }  
888 -  
889 - @Override  
890 - public int getBatchSize() {  
891 - return saveList.size();  
892 - }  
893 - });  
894 -  
895 - //写一条走向变更记录  
896 - jdbcTemplate.update("insert into logger_route_synchro(t, line_code, version) values(?, ?, ?)", System.currentTimeMillis(), station.getLineCode(), station.getVersions());  
897 -  
898 - tran.commit(status); 910 + });
899 911
900 - //返回更新之后的数据  
901 - List<GeoStation> list = findByUpdown(station.getLineCode(), station.getDirections(), station.getVersions());  
902 - rs.put("list", list);  
903 - rs.put("status", ResponseCode.SUCCESS);  
904 - } catch (Exception e) {  
905 - tran.rollback(status);  
906 - logger.error("", e);  
907 - rs.put("status", ResponseCode.ERROR);  
908 - rs.put("msg", "服务器出现异常");  
909 - }  
910 - return rs;  
911 } 912 }
912 913
913 @Override 914 @Override
src/main/resources/logback.xml
@@ -9,8 +9,7 @@ @@ -9,8 +9,7 @@
9 9
10 <layout class="ch.qos.logback.classic.PatternLayout"> 10 <layout class="ch.qos.logback.classic.PatternLayout">
11 <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符 --> 11 <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符 -->
12 - <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%file:%line] %-5level-%msg%n  
13 - </pattern> 12 + <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%file:%line] %-5level -%msg%n</pattern>
14 </layout> 13 </layout>
15 </appender> 14 </appender>
16 15
@@ -31,8 +30,7 @@ @@ -31,8 +30,7 @@
31 30
32 <layout class="ch.qos.logback.classic.PatternLayout"> 31 <layout class="ch.qos.logback.classic.PatternLayout">
33 <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符 --> 32 <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符 -->
34 - <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%file:%line] %-5level-%msg%n  
35 - </pattern> 33 + <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%file:%line] %-5level -%msg%n</pattern>
36 </layout> 34 </layout>
37 </appender> 35 </appender>
38 36
@@ -50,8 +48,7 @@ @@ -50,8 +48,7 @@
50 48
51 <layout class="ch.qos.logback.classic.PatternLayout"> 49 <layout class="ch.qos.logback.classic.PatternLayout">
52 <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符 --> 50 <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符 -->
53 - <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level -%msg%n  
54 - </pattern> 51 + <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%file:%line] %-5level -%msg%n</pattern>
55 </layout> 52 </layout>
56 </appender> 53 </appender>
57 <logger name="com.bsth.filter.AccessLogFilter" level="INFO" 54 <logger name="com.bsth.filter.AccessLogFilter" level="INFO"
@@ -72,8 +69,7 @@ @@ -72,8 +69,7 @@
72 </rollingPolicy> 69 </rollingPolicy>
73 70
74 <layout class="ch.qos.logback.classic.PatternLayout"> 71 <layout class="ch.qos.logback.classic.PatternLayout">
75 - <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%file:%line] %-5level -%msg%n  
76 - </pattern> 72 + <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%file:%line] %-5level -%msg%n</pattern>
77 </layout> 73 </layout>
78 </appender> 74 </appender>
79 <logger name="com.bsth.service.directive.DirectiveServiceImpl" 75 <logger name="com.bsth.service.directive.DirectiveServiceImpl"
@@ -102,8 +98,7 @@ @@ -102,8 +98,7 @@
102 </rollingPolicy> 98 </rollingPolicy>
103 99
104 <layout class="ch.qos.logback.classic.PatternLayout"> 100 <layout class="ch.qos.logback.classic.PatternLayout">
105 - <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%file:%line] %-5level -%msg%n  
106 - </pattern> 101 + <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%file:%line] %-5level -%msg%n</pattern>
107 </layout> 102 </layout>
108 </appender> 103 </appender>
109 <logger name="com.bsth.service.impl.TrafficManageServiceImpl" 104 <logger name="com.bsth.service.impl.TrafficManageServiceImpl"
@@ -124,8 +119,7 @@ @@ -124,8 +119,7 @@
124 </rollingPolicy> 119 </rollingPolicy>
125 120
126 <layout class="ch.qos.logback.classic.PatternLayout"> 121 <layout class="ch.qos.logback.classic.PatternLayout">
127 - <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%file:%line] %-5level -%msg%n  
128 - </pattern> 122 + <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%file:%line] %-5level -%msg%n</pattern>
129 </layout> 123 </layout>
130 </appender> 124 </appender>
131 <!-- schedule 时刻表操作日志 --> 125 <!-- schedule 时刻表操作日志 -->
@@ -141,8 +135,7 @@ @@ -141,8 +135,7 @@
141 </rollingPolicy> 135 </rollingPolicy>
142 136
143 <layout class="ch.qos.logback.classic.PatternLayout"> 137 <layout class="ch.qos.logback.classic.PatternLayout">
144 - <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%file:%line] %-5level -%msg%n  
145 - </pattern> 138 + <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%file:%line] %-5level -%msg%n</pattern>
146 </layout> 139 </layout>
147 </appender> 140 </appender>
148 <logger name="com.bsth.service.schedule.impl.TTInfoServiceImpl" 141 <logger name="com.bsth.service.schedule.impl.TTInfoServiceImpl"
@@ -171,7 +164,7 @@ @@ -171,7 +164,7 @@
171 <file>${LOG_BASE}/datasync/vehicle/vehicle-data-sync.${taskLogKey}.log</file> 164 <file>${LOG_BASE}/datasync/vehicle/vehicle-data-sync.${taskLogKey}.log</file>
172 <append>true</append> 165 <append>true</append>
173 <encoder charset="UTF-8"> 166 <encoder charset="UTF-8">
174 - <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%file:%line] %-5level-%msg%n</pattern> 167 + <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%file:%line] %-5level -%msg%n</pattern>
175 </encoder> 168 </encoder>
176 </appender> 169 </appender>
177 </sift> 170 </sift>
@@ -234,8 +227,7 @@ @@ -234,8 +227,7 @@
234 </rollingPolicy> 227 </rollingPolicy>
235 228
236 <layout class="ch.qos.logback.classic.PatternLayout"> 229 <layout class="ch.qos.logback.classic.PatternLayout">
237 - <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%file:%line] %-5level -%msg%n  
238 - </pattern> 230 + <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%file:%line] %-5level -%msg%n</pattern>
239 </layout> 231 </layout>
240 </appender> 232 </appender>
241 <logger name="com.bsth.data.gpsdata_v2" 233 <logger name="com.bsth.data.gpsdata_v2"
@@ -256,8 +248,7 @@ @@ -256,8 +248,7 @@
256 </rollingPolicy> 248 </rollingPolicy>
257 249
258 <layout class="ch.qos.logback.classic.PatternLayout"> 250 <layout class="ch.qos.logback.classic.PatternLayout">
259 - <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%file:%line] %-5level -%msg%n  
260 - </pattern> 251 + <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%file:%line] %-5level -%msg%n</pattern>
261 </layout> 252 </layout>
262 </appender> 253 </appender>
263 <logger name="com.bsth.data.gpsdata.status_manager" 254 <logger name="com.bsth.data.gpsdata.status_manager"
@@ -278,8 +269,7 @@ @@ -278,8 +269,7 @@
278 </rollingPolicy> 269 </rollingPolicy>
279 270
280 <layout class="ch.qos.logback.classic.PatternLayout"> 271 <layout class="ch.qos.logback.classic.PatternLayout">
281 - <pattern>%d{MM-dd HH:mm:ss.SSS} %-5level -%msg%n  
282 - </pattern> 272 + <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%file:%line] %-5level -%msg%n</pattern>
283 </layout> 273 </layout>
284 </appender> 274 </appender>
285 <logger name="com.bsth.data.msg_queue.WebSocketPushQueue" 275 <logger name="com.bsth.data.msg_queue.WebSocketPushQueue"
@@ -298,8 +288,7 @@ @@ -298,8 +288,7 @@
298 </rollingPolicy> 288 </rollingPolicy>
299 289
300 <layout class="ch.qos.logback.classic.PatternLayout"> 290 <layout class="ch.qos.logback.classic.PatternLayout">
301 - <pattern>%d{MM-dd HH:mm:ss.SSS} %-5level -%msg%n  
302 - </pattern> 291 + <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%file:%line] %-5level -%msg%n</pattern>
303 </layout> 292 </layout>
304 </appender> 293 </appender>
305 <logger name="com.bsth.data.msg_queue.DirectivePushQueue" 294 <logger name="com.bsth.data.msg_queue.DirectivePushQueue"
@@ -325,8 +314,7 @@ @@ -325,8 +314,7 @@
325 </rollingPolicy> 314 </rollingPolicy>
326 315
327 <layout class="ch.qos.logback.classic.PatternLayout"> 316 <layout class="ch.qos.logback.classic.PatternLayout">
328 - <pattern>%d{MM-dd HH:mm:ss.SSS} %-5level -%msg%n  
329 - </pattern> 317 + <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%file:%line] %-5level -%msg%n</pattern>
330 </layout> 318 </layout>
331 </appender> 319 </appender>
332 <logger name="com.bsth.data.schedule.thread.SchedulePstThread" 320 <logger name="com.bsth.data.schedule.thread.SchedulePstThread"
src/main/resources/static/pages/home.html
@@ -59,7 +59,7 @@ @@ -59,7 +59,7 @@
59 } 59 }
60 </style> 60 </style>
61 <div class="system_change_log"> 61 <div class="system_change_log">
62 - <h2 style="text-indent: 35px;margin: 10px 0 5px;">2023-07-31 更新说明 Changelog</h2> 62 + <h2 style="text-indent: 35px;margin: 10px 0 5px;">2023-08-06 更新说明 Changelog</h2>
63 <br><br> 63 <br><br>
64 <ul> 64 <ul>
65 <li class="sub_title"><h6>线调</h6></li> 65 <li class="sub_title"><h6>线调</h6></li>