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