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