zoukankan      html  css  js  c++  java
  • 理解国际站代码结构

    理解国际站代码结构

    O/R Mapping 是 Object Relationl Mapping(对象关系映射)的缩写。通俗点讲,就是对象与关系数据库绑定,用对象来表示关系数据。在O/R Mapping的世界里,有两个基本的也是很重要的东东需要了解一下,即VO,PO。

    VO,值对象(Value Object),PO,持久对象(Persisent Object),它们是由一组属性和属性的get和set方法组成。从结构上看,它们没有什么不同的地方。但是意义和本质上来看是完全不同的。

    1. VO是用new关键字创建,由GC回收的。PO则是向数据库中添加新的数据时创建,删除数据库时消除的。并且它只能存活在一个数据库连接中,断开连接即被销毁。
    2. VO是值对象,精确点讲它是业务对象,存活在业务层的,业务逻辑是用,它存活的目的是为数据提供一个生存的地方。PO则是有状态的,每个属性代表当前的状态。它是物理数据的对象表示。使用它,可以使我们的程序与物理数据解耦,并且可以简化对象数据与物理数据之间的转换。
    3. VO的属性是根据当前业务不同而不同的,也就是说,他的每个属性都是一一对应当前业务逻辑所需要的数据的名称。PO的属性是跟数据库表的字段一一对应的。

    PO对象需要实现序列化接口。PO是持久化对象,它只是将物理数据实体的一种对象表示,为什么需要它?因为他可以简化我们对于物理实体的了解和耦合,简单的将,他是业务对象,是生活在业务层的,是业务逻辑需要了解,需要使用的,再简单的讲,它是概念模型转换得到的。

    首先说PO和VO吧,他们的关系是相互独立的,一个VO可以只是PO的部分,也可以是多个PO结构,同样也可以等同于一个PO(当然我是指他们的属性)。正是因为这样,PO独立出来,数据持久层也独立出来了,他不收任何业务的干涉。有正是因为这样,业务逻辑层也独立开来,它不会受到数据持久层的影响,业务层关心的只是业务逻辑的处理,至于怎样存怎样读交给别人吧!不过,另外一点,如果我们没有使用数据持久层,或者说没有使用hibernate,那么PO和VO也可以是一个东西,虽然这并不好。

    PO(persistant object)持久对象。在O/R映射的时候出现的概念,如果没有O/R映射,就没有这个概念存在了。通常对应数据模型(数据库),本身还有部分业务逻辑的处理。可以看成是与数据库中表相应蛇的java对象。简单的PO就是对应数据库中某表中的一条记录,多个记录可以用PO的集合。PO中应该不包含任何数据库的操作。

    VO(value object)值对象。通常用于业务之间的数据传递,和PO一样也是仅仅包含数据而已。但应该抽象出的业务对象,可以和表对应,也可以不,这是根据业务的需要。

    TO(Transfer Object),数据传输对象。在应用程序不同关系之间传递的对象。

    BO(business Object), 业务对象。从业务模型的角度看,见UML元件领域对象。封装业务逻辑的java对象,通过调用DAO方法,结合PO,VO进行业务操作。

    POJO(plain ordinary java object),简单无规则java对象。传统意义的java独享。就是说一些Object/Relation Mapping工具中,能够做到维护数据库表记录的persisent Object完全是一个符合java Bean规范的纯Java独享,没有任何增加别的属性和方法。我的理解就是最基本的Java Bean,只有属性字段setter和getter方法。

    DAO(data access object) 数据库访问对象。是一个sun的一个标准j2ee设计模式,这个模式中有一个接口就是DAO,它负责持久层的操作。为业务层提供接口。此对象用于对访问数据库。通常和PO结合使用,DAO中包含了各种数据库的操作方法。通过它的方法,结合PO对数据库进行相关的操作。家在业务逻辑和数据库资源中间。配合VO,提供数据库的CRUD操作。

    O/R mapper 对象/关系 映射。定义好所有的mapping之后,这个O/R Mapper可以帮我们做很多工作。通过这些mappings,这个O/R Mapper可以生成所有的关于对象保存,删除,读取的SQL语句,我们不需要写那么多的DAL代码了。

    1. 实体Model——实体模式
    2. DAL——数据访问层
    3. IDAL——接口层
    4. DALFactory——类工厂
    5. BLL——业务逻辑层
    6. BOF business Object Framework ——业务对象框架
    7. SOA Service Orient Architecture —— 面向服务的设计
    8. EMF Eclipse Model Framework —— Eclipse建模框架
  • 相关阅读:
    8.5 day8
    8.1 day6
    课后作业 day29
    博客整理day29
    博客整理day28
    博客整理day27
    博客整理day26
    课后作业 day26
    Python 学习day22
    课后作业 day21
  • 原文地址:https://www.cnblogs.com/mr-cc/p/5821353.html
Copyright © 2011-2022 走看看