美文网首页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