1,实体组件只是EJB层中的实现选择之一。实体组件不应该被暴露给客户软件。WEB层和其他EJB客户软件绝不应该直接访问实体组件。它亿只应该与由实现应用业务逻辑的会话组件所构成的一个会话组件层打交道。这不仅保持了应用设计与实现中的灵活性,而且常常还改进了性能。
2,会话组件最好只通过普通JAVA数据存取接口的一个持久性门面来访问实体组件。虽然实体组件衽了一种特殊的数据处理方法,但标准JAVA接口却没有。这种方法不公保持了灵活性,而且还预见性地检验了一个应用。笔者对实体组件的未来产生了极大的怀疑,因为凡是在实体组件适用的任何地方,JDO都能提供一个更简单、更通用、性能更高的解决方案。通过使用DAO,我们仍有换用JDO或其他任一持久性策略的能力,即便在一开始就使用实体组件实现了一个应用之后。
3,实体组件通常是一 个薄层,用于具体化一个不是基于对象的数据存储器。如果使用一个像ODBMS之类的面对对象的数据存储器,这个薄层不是必需的,因为可以使用助手类从会话组件中访问这种数据存储器
4,关于实体组件的争论有两点:一)实体组件的粒度,二)实体组件是否可以实现业务逻辑。
5,一个粗实体可能会建模一条逻辑记录,而这条记录会分布于多个表中;而一个精细粒度可能会映射到单个表中;在EJB2.0 CMP中通常认为精细粒度会更加方便,虽然粗粒度的建模更利于面向对象的设计,但有一个结论就是:
在EJB2.0中,最好是通过使用CMP把实体组件用于相当精细的对象。
6,无论任何理由都不能破坏以下约定:
在实体组件中只实现持久性逻辑,不要实现业务逻辑!
7,BMP的“N+1”问题,对于BMP的find方法,它在EJB中的实现需要返回主键集合,在幕后BMP做了什么了?
如你要选取某个城市的全部人员信息,那么BMP会执行n+1次类这样的查询(n代表将要找到的记录)
SELECT PK,NAME, FROM USERS WHERE PK=
...
SELECT PK,NAME, FROM USERS WHERE PK=
如果你要查的数量少就还好,不幸的是如果你查询的记录比较多,如5000,这对于一个拥300万用户的系统来讲应该是很正常的查询,那么BMP会去自动执行5001次类似的查询。而任何正当的实现方法应该是类似以下的语句:
SELECT PK,NAME, FROM USERS WHERE PK IN
结论:不要实体组件中使用BMP,而要从无状态会话组件中使用持久性。和从一个DAO层中执行数据存取相比,使用BMP不会增加什么价值,只会增加复杂性。
8,CMP2.0引进了主业务方法(我平时叫home方法),每个实体有自己的业务方法(远程接口中定义的方法);两者均可以通过调用ejbSelect()方法来获取想要进行的逻辑操作,当然也可以作任何其它操作,如调用存储过程等。
9,应该使用DAO来分离数据数据存取与业务逻辑。当然DAO中是可以用无状态会话BEAN来实现的。
未完待续
J2EE设计模式学习笔记之--用实体组件进行数据存取
时间: 2024-10-27 17:49:56
J2EE设计模式学习笔记之--用实体组件进行数据存取的相关文章
设计模式学习笔记系列
设计模式学习笔记(二十二)-FlyWeight享元模式 设计模式学习笔记(二十一)-Composite模式 设计模式学习笔记(二十)-Visitor访问者模式 设计模式学习笔记(十九)-Chain of Responsibility职责链模式 设计模式学习笔记(十八)-Mediator中介者模式 设计模式学习笔记(十七)-Memento备忘录模式 设计模式学习笔记(十六)-Proxy模式 设计模式学习笔记(十五)-State模式 设计模式学习笔记(十四)-Command模式 设计模式学习笔记(十
设计模式学习笔记(十)—Factory Method模式
<设计模式>一书对Factory Method模式是这样描述的: 定义一个用于创建对象的接口,让子类决定实例化哪一个类.FactoryMethod使一个类的实例化延迟到其子类. 我的理解:FatoryMethod模式是一种创建型模式,定义一个用于创建对象的接口的意思是说,我们要定义一个用于创建对象的接口(或者说抽象类,实际上就是个抽象工厂abstractFactory),它的内部有一个创建对象的方法,这个方法的返回值是一个接口(或者抽象类)的类型,这个方法就是FactoryMethod:让子类
VSTO学习笔记(十四)Excel数据透视表与PowerPivot
原文:VSTO学习笔记(十四)Excel数据透视表与PowerPivot 近期公司内部在做一种通用查询报表,方便人力资源分析.统计数据.由于之前公司系统中有一个类似的查询使用Excel数据透视表完成的,故我也打算借鉴一下. 测试代码下载 原有系统是使用VBA编写的,难以维护,且对新的操作系统如Windows 7.64位架构不支持,我准备用VSTO进行重写. 数据透视表是一种交互式的表,可以进行某些计算,如求和与计数等.所进行的计算与数据跟数据透视表中的排列有关. 数据透视表是一种完全自助式
【swift学习笔记】二.页面转跳数据回传
上一篇我们介绍了页面转跳:[swift学习笔记]一.页面转跳的条件判断和传值 这一篇说一下如何把数据回传回父页面,如下图所示,这个例子很简单,只是把传过去的数据加上了"回传"两个字,回传到父页面. 我是使用protocol去实现的回传.那让我们来创建一个protocol import Foundation protocol ValueBackDelegate { func ValueBack(value: String) } protocol可以理解为interface,ValueBa
学习笔记(1)--Crystal Enterprise组件
enterprise|笔记 Crystal Enterprise组件 1. Crystal Enterprise SDK 包含许多用于创建发布web报表的工具的库.提供给用户登陆Crystal Enterprise System,创建对象(目录和报表),和察看报表,报表生成计划,导出报表的功能.2. RAS SDK 包含用于创建设计web报表的工具的库.用户可以创建新的报表,也可以对已经存在的报表添加,移除,修改对象(例如表,图,字段).3. Crystal Viewer SDK 包含用于显示w
我的设计模式学习笔记------&;gt;单例模式(Singleton)
一.前言 有些时候,允许自由创建某个类的实例是没有意义,还可能造成系统性能下降(因为创建对象所带来的系统开销问题).例如整个Windows系统只有一个窗口管理器,只有一个回收站等.在Java EE应用中可能只需要一个数据库引擎访问点,Hibernate访问时只需要一个SessionFactory实例,如果在系统中为它们创建多个实例就没有太大的意义. 如果一个类始终只能创建一个实例,则这个类被称为单例类,这种模式就被称为单例模式. 对Spring框架而言,可以在配置Bean实例时指定scope="
设计模式学习笔记(二十一)—Composite模式
今天开始学习Composite模式,首先让我们看一下它的定义: 将对象组合成树形结构以表示"整体-部分"的层次结构.Composite模式使单个对象和组合对象的使用具有一致性. 下面给出这个模式的结构图: 如果把Composite模式看成是树形结构的话,那么它主要角色有: 1)树干角色(Component):该角色是一个抽象类,它定义了一些操作增删树叶(Leaf)的操作. 2)树枝角色(Composite):树枝上有很多树干,树枝也是树干的一种. 3)树叶角色(Leaf):树干上的树叶
我的设计模式学习笔记------&;gt;Java设计模式总概况
设计模式(Design Pattern)的概念最早起源于建筑设计大师Alexander的<建筑的永恒方法>一书,尽管Alexander的著作是针对建筑领域的,但是他的观点实际上用用于所有的工程设计领域,其中也包括软件设计领域.在<建筑的永恒方法>一书中是这样描述模式的: 模式是一条由三个部分组成的通用规则:他表示一个特定环境.一类问题和一个解决方案之间的关系.每一个模式描述了一个不断重复发生的问题,以及该问题解决方案的核心设计. 软件领域的设计模式也有类似的定义:设计模式是对处于特
C#设计模式学习笔记-单例模式
本文转载:http://www.cnblogs.com/xun126/archive/2011/03/09/1970807.html最近在学设计模式,学到创建型模式的时候,碰到单例模式(或叫单件模式),现在整理一下笔记. 在<Design Patterns:Elements of Resuable Object-Oriented Software>中的定义是:Ensure a class only has one instance,and provide a global point of a