数据模型和数据库表的关系


 还是之前的整合优惠活动的项目所总结的经验。

问题

传统的web服务,都是通过数据库实现增、删、改、查,model层的javabean,一般都会和数据库某个表一一对应。但这个项目中,我无法通过数据库的查询,实现筛选我想要的数据。

         比如一个优惠活动,他有N类限制条件,如酒店名称、入住日期是星期几、刷的信用卡是哪个银行组织,用户是那个等级的,等等。

         好吧,这样看还不是很麻烦。当项目进行到一半,发现需求变了,一个优惠活动,有多个收益项目,积分、折扣、代泊车、送电影票,每个收益的限制未必相同。

         于是我就坐蜡了。

         解决办法

         穷则变,变则通。当我决定不使用数据库的查询时,整个世界豁然开朗。

         因为数据量并不大,才几百个,所以我觉得第1期版本直接用代码做查询(后期可以考虑搜索引擎)

         设计类图(简介版):

 
数据模型和数据库表的关系
 

 

         这里,活动信息,收益限制类信息,都可分表保存,在生成活动时从数据库提取数据,生成限制类(内部有判断规则)

        

         结论

         类似依赖倒置原则。Java类的设计,要优先于数据库表的设计,数据库只是为系统提供服务,而不应该成为限制系统设计的障碍。

 

         这段经历,对我在技术上没什么提升,带在分析解决问题的思路上敲了一记警钟。我以前太习惯于传统的web后端开发,在思想上太过于依赖工具。

相关推荐