2020-01-31 关于枚举与数据字典

说说什么时候使用了枚举:
框架中,使用了枚举类的注解,即数据持久化时使用注解,当参数为枚举时,存入库的信息为枚举上注解的值

数据字典:
数据字典是我们在数据库中建的表,基本包含组,key , value三个核心信息
基本方法除了curd外,可以通过对应组下的key获取value,也可以通过value获取key
举例:如省市区做组,对应的城市英文名做key,汉字描述做value

数据字典好处:
修改方便,只要对数据字典表的数据做修改,对应的参数值自然发生改变,不用重新打包项目

存在的问题:
枚举中的数据是单例数据,属于缓存数据,查询速度快,而数据库中数据字典查询较慢
解决方法:
1.使用redis将数据字典存入缓存,查询方便,缺点:redis数据过多查询变慢,需要集群部署
2.使用map将数据字典信息在项目启动时插入hashmap中,该方法可以手动实现也可以使用spring-cache来实现

新的发展方向:
可持续部署,docker-jenkins-git 当代码提交,项目自动打包发布,当新项目正常启动关闭旧项目,达到无缝切换,那么数据字段的好处也就没那么明显了,反而为了使用数据字典而建表,存缓存等方式增加了项目的复杂度

ps:数据字典往往存储通用的key-value值
但是枚举本身是对象的一种,理论来说,可以用于处理更多的信息的数据扩展性更好,当数据不满足于key-value这些简单结构的话可以使用枚举,可是话有说回来,目前nosql数据库,大家通过一些规范,可以解决复杂业务,理论来说即使属性复杂,也可以转换为简单的key-value形式;

结论:如果是项目支持可持续部署,枚举更为简单有效
如果项目打包部署不方便,数据字典是更好的选择

你可能感兴趣的:(2020-01-31 关于枚举与数据字典)