为了账号安全,请及时绑定邮箱和手机立即绑定

是直接使用字典来处理数据呢还是创建对应的Model来处理数据

是直接使用字典来处理数据呢还是创建对应的Model来处理数据

慕森王 2019-04-09 20:24:40
在群里讨论的时候讲到,有些人是直接使用字典来处理数据的,而我偏向于使用对应的Model。他们认为为每一个数据创建Model太浪费时间了,我认为使用字典的话维护性很低,可读性也很低。虽然需要花费时间去创建model,然而这个model并没有多复杂,而且也可以使用自动化工具来创建。使用字典使用Model增加了字段在使用处增加在Model中增加,在使用处使用删除了字段在使用处删除(但是没在Model中删除,在是用处删除(会有编译器有警告提醒还有没删除警告)的地方)修改了字段在使用处修改(多处)在Model中修改
查看完整描述

2 回答

?
慕哥9229398

TA贡献1877条经验 获得超6个赞

优劣问题虽然没有绝对的判断,但一个粗略的感觉还是可以有的。
最简单的一个依据就是:活数据用Model,死数据用字典。
Model就是业务数据,每天走流水,添加删除频繁的。死数据就是常年不更新的固定条目,例如全国政区表、世界时区表。
就算用字典,也不要完全写死:
略微遵守数据库设计的范式来。最起码key-value的二元架构还是必要的(以防由于错别字等原因,数据不变但显示文字略有改动)
不要太粗糙,不要一个字典变量完事,而要封装为成型的helper/utility
字典数据要动态加载,绝对不能直接硬塞到代码中(hard-code)
另一个想法就是:Modelifyoucan,dictionaryifyoumust.总用Model肯定没有错,字典只用来最小限度的解决性能问题。
                            
查看完整回答
反对 回复 2019-04-09
?
森栏

TA贡献1810条经验 获得超5个赞

个人感觉这样的问题,一般都是经验作答,2种方式通过分析来辩论,不如付诸实践,通过具体的业务来检验优劣,单一简单架构的我倾向字典,放到具体的业务对象里用model
                            
查看完整回答
反对 回复 2019-04-09
  • 2 回答
  • 0 关注
  • 351 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信