PEAA笔记四:Table Data Gateway

王朝other·作者佚名  2006-01-09
宽屏版  字体: |||超大  

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在各处使用,不然使用它并没有什么好处

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
© 2005- 王朝网络 版权所有