I’m trying to confirm now, what I believe about the Data Mapper pattern. So here we go:
Section A:
A Data Mapper is a class which is used to create, update and delete objects of another Class. Example: A class called Cat, and a Data Mapper called CatDataMapper. And a database table called cats. But it could also be an xml file called cats.xml, or an hard-coded array called cats. The whole point of that Data Mapper is to free the Business Logic which uses the Cat class from thinking about “how to get an exisiting cat”, or “how to save a cat”, “where to save a cat”. As a user of the Data Mapper it looks like a blackbox with well-defined methods like getCat(int id), saveCat(Cat catObject), deleteCat(Cat catObject), and so on.
Section B:
First I thought it would be clever if Cat inherits from CatDataMapper, because calling such functions then is a bit more convenient. For example, methods like catWithId(int id) could be static (class method) and return an instance of a Cat, initialized with data from anywhere. And when I work with a cat object in my code, I could simply call myCat->save(); to store it whereever the Data Mapper will store it (don’t care where and how, the Data Mapper hides this complexity from the user).
In conclusion, I’m a little bit confused now 😉
Do you think that Section A is valid for the Data Mapper pattern? And if I would do it additionaly as described in Section B, would that be bad? Why?
I think your Section A corresponds to the definiton of the Data Mapper pattern as given by Martin Fowler
Be careful with the details of your implementation language. In Section B having
catWithId()be a static member of thecatclass may interfere with polymorphic behavior of the method.In java, the JVM will dispatch a static method based on the declared type of the reference.
Try this out:
1. create a class
CatDataMapperwith the static methodcatWithId(int id)2. create a class
CatextendingCatDataMapperthat has the desired Business Logic behavior3. subclass
CatwithLoggedCatthat logs all activity, including the activity fromCatDataMapper4. do
Cat foo = new LoggedCat()5. do
Cat bar = foo.catWithId(5)note which method is called, it should be the static method of
CatDataMappernot the static method ofLoggedCathttp://faq.javaranch.com/view?OverridingVsHiding gives a more in-depth discussion of this.