1、 场景
当项目中存在一个枚举类,里边的数据不需要一直更新,但是在某些场景下需要进行配置时,
我们可能就要改一次数据就打一次包,这个样的话效率会很低所以可以放到配置文件中
2、 实现
3、 原始处理
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
|
@Getter @AllArgsConstructor public enum QaDataSetEnum {
ALL("1794970287076651009", "综合知识库","1"), GE_REN_RONG_YU( "1793159398708293633", "xx知识库","2"), HUI_YI("1784509150092898305", "xx知识库","3"), BIAO_ZHUN_ZHI_DU("1793160100660121601", "xxx知识库","4"), LING_DAO_PI_FU( "1793159507289374721", "xxx知识库","5"), NONE("", "空数据知识库", "6");
private final String dataSetId;
private final String logInfo;
private final String code; public static String getDataSetIdByCode(String code) {
return Steam.of(QaDataSetEnum.values()).findFirst(data -> data.code.equals(code)).orElse(NONE).getDataSetId(); }
}
|
3.1、 方法函数
1
| query.setDataset(QaDataSetEnum.getDataSetIdByCode(query.getCode()));
|
我们设置一个数据集,现在放到配置文件中
4、 放入配置文件
4、1 新增配置类
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
| @Configuration public class QaDataSetConfig {
private static final Map<String, String> ID_MAP = new HashMap<>();
@Value("${qa.dataset.all-id:}") private String allId;
@Value("${qa.dataset.bzry-id:}") private String bzryId;
@Value("${qa.dataset.hyjy-id:}") private String hyjyId;
@Value("${qa.dataset.gzzd-id:}") private String gzzdId;
@Value("${qa.dataset.ldps-id:}") private String ldpsId;
@PostConstruct public void init() { ID_MAP.put("1", allId); ID_MAP.put("2", bzryId); ID_MAP.put("3", hyjyId); ID_MAP.put("4", gzzdId); ID_MAP.put("5", ldpsId); }
public static String getId(String code) { return ID_MAP.get(code); } }
|
修改枚举类方法
1 2 3 4 5
| public static String getDataSetIdByCode(String code) {
return Opp.ofStr(QaDataSetConfig.getId(code)).orElseGet(() -> Steam.of(QaDataSetEnum.values()).findFirst(data -> data.code.equals(code)).orElse(NONE).getDataSetId());
}
|
这样就实现了将枚举里边的数据使用配置文件可以进行重写