sql >> Database >  >> NoSQL >> Redis

Efficiënte manier om gegevens uit Redis . in kaart te brengen

U kunt lui laden gebruiken, dus Roles collectie wordt alleen geladen als dat nodig is. Dit wordt gedaan door een rolrepository te injecteren in uw FullEmployee entiteit.

U kunt de rollen ook voor eens en voor altijd laden:houd een woordenboek met rollen in uw FullEmployeeMapper en vul het terwijl ze zijn geladen, controleer het dan voordat u de cache opvraagt. Hopelijk maakt u voor elke werkeenheid een exemplaar opnieuw, zodat het woordenboek voor elk nieuw werk vers is en u multithreading-problemen vermijdt.

Voorbeeldimplementatie met een 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;
    }
}


  1. Haal een bepaald element uit de mongoDB-array

  2. Koppelen en maken van MongoDB-joins met SQL:deel 3

  3. Hoe push je meldingen met angular.js?

  4. Bulkinsertprestaties in MongoDB voor grote collecties