CarsServiceImpl.java
5.49 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
package com.bsth.service.schedule.impl;
import com.bsth.entity.Cars;
import com.bsth.service.schedule.CarsService;
import com.bsth.service.schedule.exception.ScheduleException;
import com.bsth.service.schedule.utils.DataToolsProperties;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.context.properties.EnableConfigurationProperties;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.util.CollectionUtils;
import java.io.File;
import java.io.PrintWriter;
import java.io.StringWriter;
import java.util.HashMap;
import java.util.Map;
/**
* Created by xu on 16/12/8.
*/
@EnableConfigurationProperties(DataToolsProperties.class)
@Service(value = "carsServiceImpl_sc")
public class CarsServiceImpl extends BServiceImpl<Cars, Integer> implements CarsService {
/** 日志记录器 */
private static final Logger LOGGER = LoggerFactory.getLogger(CarsServiceImpl.class);
@Autowired
private DataToolsProperties dataToolsProperties;
@Override
public void importData(File file, Map<String, Object> params) throws ScheduleException {
try {
LOGGER.info("//---------------- 导入车辆基础信息 start... ----------------//");
// 创建ktr转换所需参数
Map<String, Object> ktrParms = new HashMap<>();
File ktrFile = new File(this.getClass().getResource(
dataToolsProperties.getCarsDatainputktr()).toURI());
// 通用参数,转换文件路径,excel输入文件路径,错误输出文件路径
ktrParms.put("transpath", ktrFile.getAbsolutePath());
ktrParms.put("filepath", file.getAbsolutePath());
ktrParms.put("erroroutputdir", dataToolsProperties.getTransErrordir());
super.importData(file, ktrParms);
LOGGER.info("//---------------- 导入车辆基础信息 success... ----------------//");
} catch (Exception exp) {
LOGGER.info("//---------------- 导入车辆基础信息 failed... ----------------//");
StringWriter sw = new StringWriter();
exp.printStackTrace(new PrintWriter(sw));
LOGGER.info(sw.toString());
throw new ScheduleException(exp.getMessage());
}
}
@Override
public File exportData(Map<String, Object> params) throws ScheduleException {
try {
LOGGER.info("//---------------- 导出车辆基础信息 start... ----------------//");
// 创建ktr转换所需参数
Map<String, Object> ktrParms = new HashMap<>();
File ktrFile = new File(this.getClass().getResource(
dataToolsProperties.getCarsDataoutputktr()).toURI());
// 通用参数,转换文件路径,excel输出文件名
ktrParms.put("transpath", ktrFile.getAbsolutePath());
ktrParms.put("filename", "车辆基础信息_download-");
File file = super.exportData(ktrParms);
LOGGER.info("//---------------- 导出车辆基础信息 success... ----------------//");
return file;
} catch (Exception exp) {
LOGGER.info("//---------------- 导出车辆基础信息 failed... ----------------//");
StringWriter sw = new StringWriter();
exp.printStackTrace(new PrintWriter(sw));
LOGGER.info(sw.toString());
throw new ScheduleException(exp.getMessage());
}
}
@Override
@Transactional
public void validate_nbbh(Cars cars) throws ScheduleException {
// 查询条件
Map<String, Object> param = new HashMap<>();
if (cars.getId() != null) {
param.put("id_ne", cars.getId());
}
param.put("insideCode_eq", cars.getInsideCode());
if (!CollectionUtils.isEmpty(list(param))) {
throw new ScheduleException("车辆内部编号/自编号重复");
}
}
@Override
@Transactional
public void validate_clbh(Cars cars) throws ScheduleException {
// 查询条件
Map<String, Object> param = new HashMap<>();
if (cars.getId() != null) {
param.put("id_ne", cars.getId());
}
param.put("carCode_eq", cars.getCarCode());
if (!CollectionUtils.isEmpty(list(param))) {
throw new ScheduleException("车辆编号重复");
}
}
@Override
@Transactional
public void validate_cph(Cars cars) throws ScheduleException {
// 查询条件
Map<String, Object> param = new HashMap<>();
if (cars.getId() != null) {
param.put("id_ne", cars.getId());
}
param.put("carPlate_eq", cars.getCarPlate());
if (!CollectionUtils.isEmpty(list(param))) {
throw new ScheduleException("车牌号重复");
}
}
@Override
@Transactional
public void validate_sbbh(Cars cars) throws ScheduleException {
// 查询条件
Map<String, Object> param = new HashMap<>();
if (cars.getId() != null) {
param.put("id_ne", cars.getId());
}
param.put("equipmentCode_eq", cars.getEquipmentCode());
if (!CollectionUtils.isEmpty(list(param))) {
throw new ScheduleException("设备编号重复");
}
}
}