软件工程

本类阅读TOP10

·PHP4 + MYSQL + APACHE 在 WIN 系统下的安装、配置
·Linux 入门常用命令(1)
·Linux 入门常用命令(2)
·使用 DCPROMO/FORCEREMOVAL 命令强制将 Active Directory 域控制器降级
·DirectShow学习(八): CBaseRender类及相应Pin类的源代码分析
·基于ICE方式SIP信令穿透Symmetric NAT技术研究
·Windows 2003网络负载均衡的实现
·一网打尽Win十四种系统故障解决方法
·数百种 Windows 软件的免费替代品列表
·收藏---行百里半九十

分类导航
VC语言Delphi
VB语言ASP
PerlJava
Script数据库
其他语言游戏开发
文件格式网站制作
软件工程.NET开发
PEAA笔记四:Table Data Gateway

作者:未知 来源:月光软件站 加入时间:2005-2-28 月光软件站

What is it
 Table Data Gateway是扮演一个数据表的对象,通过它可以处理所有对表的访问和操作。
 很多开发者并不熟悉SQL,即使那些熟悉的也不见得能够把程序写好。将操作访问数据表的CRUD操作都放在Table Data Gateway对象中,开发者就可以调用该对象的接口来和数据表进行交互

How it works
 Table Data Gateway经常是无状态的,只是负责数据从数据库进出。
 使用中比较有技巧的是如何处理从请求中返回的多个项,因为很多我们使用的编程语言只能返回一个值。一个方法是使用Map,Map是一个简单的数据结构,可以把数据库的返回项映射到Table Data Gateway中,但是这个方法必须要把数据从RecordSet中拷贝出来到Map中,而且失去了编译时刻检验,接口上也不清楚。另一个方法是使用Data Transfer Object。
 在Dotnet等很多使用Record Set的环境下,Table Data Gateway可以和Table Module等模式很好的使用。Table Data Gateway也可以通过返回Domain Object的方法来和Domain Model一起使用,不过这样并不好,两个模式会紧密地联系在一起,难以分离。
 一般的Table Data Gateway的一个实例对应数据库中的一个表,对于一些简单的情况,你甚至可以用一个实例操作所有的表。通过Data View而不是Data Table来访问数据库也可以减少其同数据库结构之间的耦合。不过使用Data View时,常常不能够Update。

When to use it
 Table Data Gateway几乎是最为简单的数据库接口,它能够很好的封装操作数据库数据的实际过程。它可以和Table Module模式很好的配合,事实上,基本想不出Table Module会使用的其他数据库接口。在Domain Model模式中很少用到它,因为Data Mapper提供了更好的数据隔离功能。
 和Row Data GateWay一样,Table Data Gateway也能很好的配合Transaction Scripts使用,取舍在于你要如何处理多行的数据。很多人倾向使用Data Transfer Object,但是除非同样的Data Transfer Object在各处使用,不然使用它并没有什么好处
 




相关文章

相关软件