实现功能
在项目启动时将字典表中的字典项加载到内存,通过静态工具类的静态map,支持根据key查询value,根据value查询key。
@Component
public class CacheUtils {
public static Map<String, BiMap<String, String>> lMap = Maps.newHashMap();
@Autowired
private BaseDictMapper mapper;
@Autowired
private BaseDictService service;
@PostConstruct
public void init() {
List<BaseDict> list = mapper.selectTypes();
for (BaseDict dict : list) {
QueryWrapper<BaseDict> queryWrapper = new QueryWrapper<>();
queryWrapper.eq("TYPE", dict.getType());
List<BaseDict> typeList = service.list(queryWrapper);
BiMap<String, String> listMap = HashBiMap.create();
for (BaseDict dict1 : typeList) {
listMap.put(dict1.getName(), dict1.getValue());
}
lMap.put(dict.getType(), listMap);
}
}
}
@Mapper
public interface BaseDictMapper extends SuperMapper<BaseDict> {
@Select("select distinct(type) from base_dict ")
List<BaseDict> selectTypes();
}
CREATE TABLE `base_dict` (
`ID` bigint(20) NOT NULL AUTO_INCREMENT,
`NAME` varchar(20) DEFAULT NULL COMMENT '标签名称',
`VALUE` varchar(20) DEFAULT NULL COMMENT '标签值',
`TYPE` varchar(20) DEFAULT NULL COMMENT '类型',
`DESCRIPTION` varchar(255) DEFAULT NULL COMMENT '中文描述',
`PARENT_ID` int(11) DEFAULT NULL COMMENT '父节点id',
`REMARK` varchar(255) DEFAULT NULL COMMENT '备注',
`CREATE_TIME` datetime DEFAULT NULL COMMENT '创建时间',
`UPDATE_TIME` datetime DEFAULT NULL COMMENT '更新时间',
`YN` int(11) DEFAULT NULL COMMENT '是否有效,1有效,0失效',
PRIMARY KEY (`ID`),
KEY `DICT_VALUE` (`VALUE`),
KEY `DICT_LABEL` (`NAME`)
) ENGINE=InnoDB AUTO_INCREMENT=0 DEFAULT CHARSET=utf8 COMMENT='字典';
lmap存储字典中的所有字典项,根据type查询对应类型的name和value。返回的BiMap支持根据key查询value,
inverse()可以将value和key反转,根据value查询key。lmap获取的结构如下:
guava BiMap
BiMap是一个双向关联的数据结构,而它对key和value严格的保证唯一性。
如果使用put方法添加相同的value值或key值则会抛出异常:java.lang.IllegalArgumentException;
如果使用forcePut方法添加则会覆盖掉原来的value值。
inverse方法会返回一个反转的BiMap,但是注意这个反转的map不是新的map对象,它实现了一种视图关联,对于反转后的map的所有操作都会影响原先的map对象。
@PostConstruct
spring中Constructor、@Autowired、@PostConstruct的顺序(网上解释比较清楚的版本)
要将对象p注入到对象a,那么首先就必须得生成对象p与对象a,才能执行注入。所以,如果一个类A中有个成员变量p被@Autowired注解,那么@Autowired注入是发生在A的构造方法执行完之后的。
如果想在生成对象时候完成某些初始化操作,而偏偏这些初始化操作又依赖于依赖注入,那么就无法在构造函数中实现。为此,可以使用@PostConstruct注解一个方法来完成初始化,@PostConstruct注解的方法将会在依赖注入完成后被自动调用。
Constructor >> @Autowired >> @PostConstruct
@Component
public class ExcelListener extends AnalysisEventListener {
public static ExcelListener listener;
@Autowired
private ApiInfoService apiInfoService;
@Autowired
private ApiInfoImportErrorService apiInfoImportErrorService;
/**
* 通过@PostConstruct实现初始化bean之前进行的操作
* 解决apiInfoService 无法注入的问题
*/
@PostConstruct
public void init(){
listener = this;
listener.apiInfoService = this.apiInfoService;
listener.apiInfoImportErrorService = apiInfoImportErrorService;
}
...
}
ExcelListener在使用apiInfoService时无法自动注入,通过定义一个静态变量 listener,使用@PostConstruct方法来初始化。