Możesz użyć leniwego ładowania, więc Roles
kolekcja jest ładowana tylko w razie potrzeby. Odbywa się to poprzez wstrzyknięcie repozytorium ról do twojego FullEmployee
podmiot.
Możesz także załadować role raz na zawsze:zachowaj słownik ról w swoim FullEmployeeMapper
i wypełnij go, gdy są ładowane, a następnie sprawdź to przed wysłaniem zapytania do pamięci podręcznej. Mamy nadzieję, że odtworzysz instancję dla każdej jednostki pracy, dzięki czemu słownik będzie świeży dla każdej nowej pracy i unikniesz problemów z wielowątkowością.
Przykładowa implementacja z List
:
class FullEmployeeMapper : IMapToNew<Employee, FullEmployee>
{
private List<FullRole> _roles = new List<FullRole>();
public FullEmployee Map(Employee source)
{
FullEmployee employee = new FullEmployee()
{
Id = source.Id,
Age = source.Age,
BirthDate = source.BirthDate,
Name = source.Name
};
var mapper = new FullRoleMapper();
var client = new RedisClient("localhost");
employee.Roles = _roles.Where(r => source.Roles.Contains(r.Id)).ToList();
if (employee.Roles.Count != source.Roles.Count)
{
var newRoles = client
.As<Role>()
.GetByIds(source.Roles.Except(employee.Roles.Select(r => r.Id)))
.Select(r => mapper.Map(r)))
.ToList();
employee.Roles.AddRange(newRoles);
_roles.AddRange(newRoles);
}
return employee;
}
}