PEAA笔记四:Table Data Gateway

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值