美文网首页springbootjava 设计
springboot 启动时加载数据(字典)到内存

springboot 启动时加载数据(字典)到内存

作者: G_XM_38d3 | 来源:发表于2019-12-07 20:41 被阅读0次

实现功能

在项目启动时将字典表中的字典项加载到内存,通过静态工具类的静态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获取的结构如下:

1575720887078.png

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方法来初始化。

相关文章

网友评论

    本文标题:springboot 启动时加载数据(字典)到内存

    本文链接:https://www.haomeiwen.com/subject/fezugctx.html