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来帮助你完成展现工作 
 
  |