EJB设计模式(四)

在设计模式3中我们看到使bean从struct继承后使得代码大幅缩水并且所有的字段都可定义为cmp字段。这里,我们可以更进一步修正setdata()和getdata()的实现方法来减少代码量。

我们为这个struct增加一个方法。

value Object code snippet for Company
public class CompanyStruct implements
java.io.Serializable {
public Integer comId;
public String comName;
public String comDescription;
public Timestamp mutationDate;
public void copyFrom(CompanyStruct struct) {
comId = struct.comId;
comName = struct.comName;
comDescription = struct.comDescription;
mutationDate = struct.mutationDate;
}
}

由于entity bean是从struct继承下来的,在bean的实现类中也一样可以引用copyfrom()方法,当然,必须注意的是,这个copyfrom()方法并不是一个商业方法,它不需要在bean的远程接口中暴露给调用者。

现在,getdata()和setdata()方法可以简化更进一步的简化。

Code snippet for an Entity Bean’s getData()
public CompanyStruct getData() {
CompanyStruct result = new CompanyStruct();
result.copyFrom(this);
return result;
}

这里把this作为一个参数传入copyfrom()。由于enttity bean从struct继承而来,于是这个entitty bean便可以作为一个struct传入。

EJB容器并不赞成把this指针作为一个参数传递因为在两个控制线程中同时访问一个bean的实例可能会引起事务冲突。但事实上我们所做的并没有违背这个原则,因为我们的并没有在bean之间传递this的引用并且也没有引用任何可能引起事务冲突的方法。

Code snippet for an Entity Bean’s setData()
public void setData(CompanyStruct struct) {
this.copyFrom(struct);
}

对于一个映射到有很多列的表的entity bean,这种实现方法的优点是使得bean实现类的代码非常简单。这种设计模式使得代码及其精简,可读性和可维护性也大大增强。任何数据库的修改都只需要修改作为基类的struct,而几乎不需要修改bean的代码。把这种改变从struct分离出来,当cmp字段发生改变时需要修改部署描述符。这就使得开发时能够更好的适应设计的改变。

这里,还是没有实现bean之间的关系,这将在设计模式5中解决。

时间: 2024-07-28 15:15:01

EJB设计模式(四)的相关文章

EJB设计模式5

就像我们在设计模式4中看到的, Entity Bean的实现大小被缩减到在ejbCreate(), getData()and setData()方法中的仅仅几行,不管CMP字段的数目.下一步是建模公司和雇员的Entity Beans,这个有点繁琐而且建议读者先对borland公司的<EJB程序员指南>的OR Mapping和高级CMP有所了解. 对这个关系建模根本不需要对结构的代码变化,然而Entity Beans实现类需要一点点修改来反映两个实体间的关系,鉴于此Deployment Desc

EJB设计模式(二)

为了避免设计模式1的缺点,我们介绍一下封装entity bean值域的value objec的概念.value object,用某些语言的术语来说,就是一个结构类型,因为他们和corba的结构类型非常类似. value Object code snippet for Company public class CompanyStruct implements java.io.Serializable { public Integer comId; //Primary Key public Stri

EJB设计模式(三)

在设计模式2中我们看到,在entity bean和struct之间有很多重复的代码比如同样的字段声明(对应数据库中的表列). 如果让entity bean从结构继承下来就可以避免冗余的代码.但是这种设计,仍然不能显示beans之间的联系. Code snippet for Company Entity Bean public class CompanyBean extends CompanyStruct implements EntityBean { EntityContext entityCo

EJB设计模式(一)

第一个设计模式非常简单.一个公司和雇员的Entity Bean和下面给出的Entity Bean的代码片断是类似的.它们是由jbuilder4的EntityBean模版生成的.所有的字段都声明为public的cmp字段. Code snippet for Company Entity Bean public class CompanyBean implements EntityBean { EntityContext entityContext; public Integer comId; //

交互设计模式(四)-SpatialMemory(空间记忆)

[版权声明]:版权归作者Alite所有,转载时请以超链接形式标明文章原始出处和作者信息及本声明:http://www.alitedesign.com/ 上期回顾:交互设计模式(三)-Tagging(标签) 当人们进入一个全新环境时,他们需要对空间建立认知模型,要有个空间记忆的感觉.同样,当新用户来到全新.陌生的网站时,用户也希望有个类似站点地图的东西.但如果想让用户更加自如的使用网站,让用户毫无顾及的去尝试,不怕迷路,我们必须为用户建立起空间记忆模式.它犹如沙漠中迷途者手中的指南针与行驶在荒原上

.NET中的设计模式四:命令模式

设计 命令模式(Command)结构并不复杂,简单的说,就是将某些职责封装成对象,对象的激发者(Invoker)和接收者(Reciever)都不过问命令的执行过程.用这样的方式解除了激发者和接受者之间的耦合,为程序提供了更清晰的层次结构.实际运用中经常是将系统中的命令抽象成一个接口,所有的命令都是这个接口的实现,如下所示: Command类是ICommand的实现,Command类实现了execute方法,其他命令类都是Command方法的子类.这样激发者接受者和接受者面临的环境就非常简单了:统

推荐一种EJB设计模式

/*** 此文从重粒子空间转而来,已经原作者的同意* 在看此文前,请先看Sun的一篇文章* http://developer.java.sun.com/developer/technicalArticles/ebeans/ejbperformance/*///----------------------------------------原文发下呵呵,我试试,我的表述和组织能力不是很好 ^o^----------------------------------------------------

EJB 3.0规范全新体验

规范 引言 期待以久的EJB3.0规范在最近发布了它的初稿.在本文中将对新的规范进行一个概要性的介绍,包括新增的元数据支持,EJBQL的修改,实体Bean模型访问bean上下文的新方法和运行时环境等等.作者还讨论了EJB在未来要作出的调整以及EJB3.0与其他开发规范之间的关系. 开始 无论如何由于EJB的复杂性使之在J2EE架构中的表现一直不是很好.EJB大概是J2EE架构中唯一一个没有兑现其能够简单开发并提高生产力的组建.EJB3.0规范正尝试在这方面作出努力以减轻其开发的复杂性.EJB3.

企业JavaBean(EJB) 3.0 全新体验

期待以久的EJB3.0规范在最近发布了它的初稿.在本文中将对新的规范进行一个概要性的介绍,包括新增的元数据支持,EJBQL的修改,实体Bean模型访问bean上下文的新方法和运行时环境等等.作者还讨论了EJB在未来要作出的调整以及EJB3.0与其他开发规范之间的关系. 开始 无论如何由于EJB的复杂性使之在J2EE架构中的表现一直不是很好.EJB大概是J2EE架构中唯一一个没有兑现其能够简单开发并提高生产力的组建.EJB3.0规范正尝试在这方面作出努力以减轻其开发的复杂性.EJB3.0减轻了开发