采用SimpleValue 解决TOP编程时候的视图层问题(上)

  OOP使用已经很久,并被广大开发人员所信奉,好处实在是很多,我在这里并不是要唱反调,鼓励大家使用TOP,但在使用OOP的时候仍然有俩个众所周知的问题:
  一是持久层一般是关系数据库,从对象映射到关系数据库不是一个很自然的事情,因此,需要添加一ORM层来实现对象到关系数据库的映射
  二是在OOP架构中的视图层中,大部分情况是展现单表,即使一个对象是由多个对象组合,展现层通过诸如"查看详细信息"这样的方式展现其他信息,因此在视图层用组织业务逻辑的对象来来展现,有时候大不可必要,而且.为了展现,有可能要为对象增加一些展示的方法.
  当业务逻辑是比较复杂的,采用OOP,虽然带来了这俩个问题,仍然是非常值得的,然而,如果业务逻辑比较简单,我就推荐你实用TOP的方式,即table-oriented programming,使用它,数据库访问和数据展现都将非常自然,而且,你可能会拥有不少工具来帮助你的开发.
  先介绍一下TOP的概念,然后说说使用它在展现层会碰到的问题,最后提出使用SimpleValue来解决这些问题.
  TOP是面向数据库表编程的意思,解决业务逻辑,采用的是Table Module(Martin Fowler,PAEE);数据库访问采用的是Row Data Gateway(Martin Fowler,PAEE),对于有简单逻辑的业务,很适合采用它.举个用例来说:根据雇员姓名查询雇员详细信息
  数据库表:员工表和部门表,员工属于一个部门
  create table EMPLOYE
  (
   ID NUMBER(9) primary key,
   NAME VARCHAR(20),
   SEX  NUMBER(1),
   DEPARTMENT_ID  NUMBER(5)   
   
  )
 
  create tale DEPARTMENT
  (
   ID NUMBER(9) primary key,
   NAME VARCHAR(20),
   P_ID NUMBER(9)
      
  )
 
  public class Employe
  {
   public int id;
   public String name;
   public int sex;
   public int dptId;
   static String sql = "select * from EMPLOYE where id = ? ";
   public static Employe getEmploye(int id) throws ApplicationException;
   {
    Employe emp = new Employe();
    Connection conn = null;
    
    try
    {
     conn = DBHelper.getConnection();
     PreparedStatement ps = conn.con.prepareStatement(sql);
     ............... 
    }
    catch(SQLException sqle)
    {
     throw new ApplicationException(sqle.getMessage());
    }
    finally
    {
     DBHelper.cleanup(conn);
    }
    return emp;
    
    
   }
  }
 
  public class Department
  {
   public int id;
   public String name;
   public int pid;
   static String sql = "select * from DEPARTMENT where id = ? ";
   static String allsql = "select * from DEPARTMENT ";
   
   public static Department getDept(int id) throws AplicationException
   {
    Department dept = new Department();
    //......
    return dept;
    
   }
   
   public static Department[] getAllDept() throws AplicationException
   {
    List depts = new ArrayList();
    //......
    return (Department[])depts.toArray(new Department[depts.size()]);
    
   }
  }
 
 
  上面的例子是TOP编程常见的风格,在此不多讲,可以参考PEEA进一步了解.现在采用TOP编程出现的问题是在显示某个值对象(区别于oo的对象),比如,显示某个用户的详细信息的时候,部门名称得显示出来而不是显示部门id.对于面向对象编程,你需要修改Emploee对象,增加一属性申明public Department dept,并在你的O/R Mapping 层做不少的代码修改工作或者配置工作(如果你用了hibernate这样的工具完成mapping).对于TOP编程来说,可采用的办法就是适用SimpleValue来帮助你完成展现工作
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值