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