With regards to my recommendation to avoid the repository, Stan asks:
You returned to explain why repository pattern is evil. Just interesting to know what are you doing when you need in your model to access another aggregate. Do you reference NH from your model? I prefer to leave my model POCOed and wrap DB calls by repository pattern. Sleeping good with it.
This is an interesting question. There are several ways to answer that. To start with, assuming that we are using DDD model (which the usage of a repository would imply), you don’t have references between aggregates.
But let us assume that we somehow need that, Stan seems to suggest something like this proposed solution:
public class Person { public static readonly DateTime ImportantDate; public BirthPlace BirthPlace { get; set; } public DateTime BirthDate { get; private set; } public void CorrectBirthDate(IRepository<BirthPlace> birthPlaces, DateTime date) { if (BirthPlace != null && date < ImportantDate && BirthPlace.IsSpecial) { BirthPlace = birthPlaces.GetForDate(date); } } }
Here we have a business rule that states that this is required.
But do we actually need a repository here? What if we just said that whoever calls us need to provide us with a way to get the birth place by date?
public void CorrectBirthDate( Func<DateTime, BirthPlace> getBirthPlaceFordate, DateTime date) { if (BirthPlace != null && date < ImportantDate && BirthPlace.IsSpecial) { BirthPlace = getBirthPlaceFordate(date); } }
This can be done with a simple delegate, no need to introduce a heavy weight abstraction. This is a local solution for a local problem. It keeps the database out from your entities and more importantly, it allows you to actually craft the appropriate response to this at the time of the call.