jeecg数据字典模块界面.png
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 等。