数据字典用途
一个系统总会存在一些编码与名称的对应关系,编码用于代码里的唯一标识,名称用于显示给用户理解,比如性别“男”、“女”,在代码里可能就用“1”、“2”来表示。为了方便维护及扩展这些编码与名称关系,需要有一个专门的模块来对数据进行管理。
jeecg数据字典的表结构解读
从上面的界面截图,我们可以分析得到数据字典模块分为两个层次结构,一个是左侧的字典分类,另一个是右侧的每个分类下的类型列表。因此,在数据结构上采用了两张表来存储,t_s_typegroup 表记录字典分类,主要字段有 typegroupcode(字典Code), typegroupname(字典名称);t_s_type 表记录类型列表,主要字段有 typecode(类型编码),typename(类型名称),typegroupid(字典分类的主键)。
缓存处理
在界面截图上,我们还能看到一个“刷新字典缓存”的按钮。由于数据字典保存的数据基本都是插入后就很少修改或删除的,是属性读多写少的操作,使用缓存能极大提升读取的性能,减少频繁读取数据库的压力。jeecg的缓存操作放在 ResourceUtil 工具类,而数据字典的缓存则是这个类里的静态变量 allTypeGroups 及 allTypes,用一个 HashMap 来缓存从数据库中查出来的字典分类和类型列表,在增删改或刷新缓存时维护这两个变量的元素即可。
多种实现方式
我在做管理后台的时候也自己实现过多个版本的数据字典模块,但基本模式就是以下两种:一、与jeecg的实现类似,分开分类表和类型列表表;二、把这两张表合在一起,通过一个 data_type 字段标识数据类型, 然后一个 parent_code 类型表内自关联上级分类,形成一张树状结构的数据字典表。而缓存的方式除了jeecg这种 HashMap 缓存外,还可以引入专业的缓存模块如 ehcache, memcached, redis 等。