数据模型和数据库表的关系
还是之前的整合优惠活动的项目所总结的经验。
问题:
传统的web服务,都是通过数据库实现增、删、改、查,model层的javabean,一般都会和数据库某个表一一对应。但这个项目中,我无法通过数据库的查询,实现筛选我想要的数据。
比如一个优惠活动,他有N类限制条件,如酒店名称、入住日期是星期几、刷的信用卡是哪个银行组织,用户是那个等级的,等等。
好吧,这样看还不是很麻烦。当项目进行到一半,发现需求变了,一个优惠活动,有多个收益项目,积分、折扣、代泊车、送电影票,每个收益的限制未必相同。
于是我就坐蜡了。
解决办法:
穷则变,变则通。当我决定不使用数据库的查询时,整个世界豁然开朗。
因为数据量并不大,才几百个,所以我觉得第1期版本直接用代码做查询(后期可以考虑搜索引擎)
设计类图(简介版):
这里,活动信息,收益限制类信息,都可分表保存,在生成活动时从数据库提取数据,生成限制类(内部有判断规则)
结论:
类似依赖倒置原则。Java类的设计,要优先于数据库表的设计,数据库只是为系统提供服务,而不应该成为限制系统设计的障碍。
这段经历,对我在技术上没什么提升,带在分析解决问题的思路上敲了一记警钟。我以前太习惯于传统的web后端开发,在思想上太过于依赖工具。
相关推荐
周公周金桥 2020-09-06
zjuwangleicn 2020-09-04
hellowzm 2020-08-18
大象从不倒下 2020-07-31
AlisaClass 2020-07-19
尚衍亮 2020-06-12
淡风wisdon大大 2020-06-06
黎豆子 2020-05-07
hilary0 2020-05-04
zhanghao 2020-04-21
MaureenChen 2020-04-21
xingguanghai 2020-03-13
nercon 2020-02-22
impress 2020-02-20
ajaxtony 2020-02-18
teresalxm 2020-02-18
福叔 2020-02-16
mituan 2020-01-17