后端字典的优雅设计

背景

今天讲到的是数据字典的设计。为什么要讲到这个呢,因为我下午在做开发的时候遇到了一个问题。我先扔出来某个表的字段的定义吧:

sql 复制代码
business_type int default 0 comment '0:收款计划;1:付款计划'

而且我还有一个字典表,字典表的结构大约是这样的:

dict_code Code Value
business_type 0 收款计划
business_type 1 付款计划

一看到这个,我就觉得尴尬了,这个样我查出来的数据字段business_type: 1,前端自己也要定义一个字典,然后自己格式化的显示成付款计划。OK,我们思考一下这样的问题:

  1. 这个数据字典的定义的意义在哪里?
  2. 我的数据字典万一key、value的值变了,对不起,将迎来接近于灭顶之灾!字段的注释需要变、后端代码需要变、前端的字典变,总之就是变变变。

我也总结一下我自己在看这么多的代码和职业生涯中遇到的比较奇葩的处理方式:

  1. 直接left join字典表
sql 复制代码
select * from user left join t_dict on user.business_type = t_dict.code
  1. 直接在代码里干
java 复制代码
User user = userDao.findByUserId(12);
// user里边有一个冗余的字段 bussinessTypeStr
if (user.getBusinessType() == 1) {
  user.setBusinessType("付款计划");
}
  1. 无情,直接交给前端的妹子
javascript 复制代码
<p>业务类型: {{ businessType | formatBusinessType }}</p>

单我这样说,找不到老婆是有原因的!

我们自己反思一下,其实自己的心里就过意不去的。当然,shigen也在不断的反思自己,遇到这样的代码的时候,自己是怎样处理的。当然,我承认:第三种还是哦比较用的多的。一个是项目代码实在是太shi了,二是需求太赶了,代码写的再优雅有什么用,没人重视。

那今天,我就要出一个教程,实现字典的混乱终结,你会爱上这种处理方式。

实现

字典表的定义我就话不多说,直接干sql语句:

我想一眼看得出来是干嘛的吧,不行再上UML图:

接下来增删改查的接口需要吧,代码生成器直接干:

sorry

行文至此,我必须先说一声sorry,因为我参考了如下的参考文章的方式,觉得并不是最优雅的。关于字典的设计和使用,我只能在字典表的设计上有一种很清晰的认识,至于使用上,我觉得我自己还不是很熟,如后端的枚举类的设计、前端的字典设计,这些都和数据库的设计严格的且分开了,不能实现动态的配置。

更好的设计方式,我还在进一步的研究中。我很sorry纠结了两天的时间还是没有得到很好的解决。但是我相信问题的扔出总会有好的解决方式的,我也在研究ruoyi-vue的代码,期待在其中找到好的解决方案。进一步的设计和心得我将会持续的分享和输出。

参考文章:Spring boot中优雅的实现字典管理(

相关推荐
AZaLEan__8 分钟前
多源 BFS
java·开发语言·算法
程序员卷卷狗10 分钟前
Java转Go面试速记:Go基础22问,一篇理清高频易错点一篇理清高频易错点
java·面试·golang
zzzzz36915 分钟前
快速搭建SpringAi项目 集成智能问答,RAG,FUINCTION_CALLING等功能
java·ai编程
步十人16 分钟前
【Redis】持久化机制
数据库·redis·缓存
笨蛋不要掉眼泪21 分钟前
Java并发编程 :深入剖析LinkedBlockingQueue
java·开发语言·网络·并发
未若君雅裁40 分钟前
算法复杂度与数据结构:Java 集合篇的第一块基石
java·数据结构·算法
Digital_Sunrise42 分钟前
首发!检测你是否被中转站注入提示词攻击!
后端
fliter1 小时前
Rust 中的小字符串:smol_str 与 smartstring 的对决
后端
致Great1 小时前
Claude Code 上线 Dynamic Workflows:一句话调度 1000 个子智能体并行干活
java·linux·服务器
一个做软件开发的牛马1 小时前
Java 常用类:String不可变、新时间API与包装类陷阱
java·后端