您的位置:中国风网 > 电脑之家 > 数 据 库

数据库学习:多类型业务处理设计技巧

中国风网 2004-3-25 17:51:12





  在企业应用开发中经常会出现多类型业务处理工作,一种好的设计方法会给应用和维护带来很大的收益,我们从一个简单的案例开始说起。

  一个图书销售系统在客户付款结算处理:

  客户分类:普通消费者、一般会员、VIP会员、其他类型待定。

  处理要求:普通消费者不享受优惠

  一般会员享受9.5折优惠

  VIP会员享受8折优惠,外加累计积分

  其他类型待定

  下面就到具体实现了,在实现的时候我们大多数人都会想到给结算操作编写一个方法(函数),在函数中我们会这样写:

  String ls_Customer_Type

  Double ld_Payment

  //取消费者类型

  ls_Customer_Type = ..............

  if ls_Customer_Type = "G" then //普通消费者

  //处理过程

  elseif ls_Customer="V"//VIP消费者

  //处理过程

  elseif

  .....
  
  end if

  //其他处理

  return ld_Payment

  或者使用choose case来代替if elseif语句,结构会倾斜些。

  这样的处理方法,对于调式、阅读、和以后新类型的增加都不大方便。假如每一个类型的处理都有很多行代码(几十行到上百行),大家在阅读的时候比较难受了,再增加一个新的类型就需要修改该方法,代码会更长,每个处理使用的变量也很容易出现交叉,程序容错变得困难。

  面对以上问题,我的设计方法是为每种类型单独创建一个方法,都提供一个相同的接口,再者还需要一个方法来接收请求和返回结果。这样,无论在调试还是运行的时候都很清晰,一个方法对应一个处理,增加新的类型的时候增加一个方法不需修改其他方法内容,程序阅读也相对轻松很多。

  具体设计实现:

  创建结算处理对象:uo_Balance

  balance的方法:of_GetPayment(as_Customer_Type) //外部访问处理

  of_GetGeneralPayment() //普通客户结算处理

  of_GetVIPPayment() //VIP会员结算处理

  of_OtherPayment() //其他处理

  of_GetPayment 方法实现:

  Double ld_Payment

  choose case as_Customer_Type

  case "G" //普通

  ld_Payment = of_GetGeneralPayment()

  case "V" //vip

  ld_Payment = of_GetVipPayment()

  case else

  ld_Payment = of_OtherPayment()

  end choose

  return ld_Payment

  of_GetGeneralPayment 方法实现:

  Double ld_Payment

  //结算处理

  return ld_Payment

  of_GetVIPPayment() of_OtherPayment() 处理方式与of_GetGeneralPayment()一致。

  处理调用:

  uo_Balance luo_Process

  String ls_Customer_Type

  Double ld_Payment

  luo_Process = create uo_Balance

  //取消费者类型

  ls_Customer_Type = ..............

  ld_Payment = luo_Process.of_GetPayment()

  //其他处理

  到此设计完成。

  以上是本人的个人经验总结,有不足之处请大家指正。


文章来源:CSDN


推荐给您的朋友】    【发表评论】    【关闭窗口

 ■:相 关 文 章

 紧急救援:用户自定义的数据库修复(续)  (3月18日17:0:14)
 紧急救援:用户自定义的数据库修复  (3月18日16:59:37)
 微软韩国换帅 主攻目标服务器、数据库市场  (3月3日16:45:19)
 SAP高管讽刺甲骨文 称其数据库产品不纯粹  (3月1日15:46:4)
 Oracle数据库及应用程序优化  (2月24日17:6:58)
 数据库基础学习:并发问题详述  (2月17日17:4:51)
 甲骨文9i数据库存在安全漏洞   (2月14日15:28:39)
 数据库学习:查询区分大小写  (2月10日16:33:19)
 有效提高WebSphere数据库性能   (2月7日17:12:12)