Pregunta Linq-to-SQL ToDictionary ()


¿Cómo convierto correctamente dos columnas de SQL (2008) usando Linq en un diccionario (para el almacenamiento en caché)?

Actualmente recorro el b / c de IQueryable. No puedo hacer que el método ToDictionary funcione. ¿Algunas ideas? Esto funciona:

var query = from p in db.Table
            select p;

Dictionary<string, string> dic = new Dictionary<string, string>();

foreach (var p in query)
{
    dic.Add(sub.Key, sub.Value);
}

Lo que realmente me gustaría hacer es algo como esto, que no parece funcionar:

var dic = (from p in db.Table
             select new {p.Key, p.Value })
            .ToDictionary<string, string>(p => p.Key);

Pero me sale este error: No se puede convertir de 'System.Linq.IQueryable' a 'System.Collections.Generic.IEnumerable'


74
2017-10-28 22:50


origen


Respuestas:


var dictionary = db
    .Table
    .Select(p => new { p.Key, p.Value })
    .AsEnumerable()
    .ToDictionary(kvp => kvp.Key, kvp => kvp.Value)
;

112
2017-10-28 22:53



Usted solo está definiendo la clave, pero necesita incluir el valor también:

var dic = (from p in db.Table
             select new {p.Key, p.Value })
            .ToDictionary(p => p.Key, p=> p.Value);

14
2017-10-28 22:57



Gracias chicos, sus respuestas me ayudaron a solucionar esto, deberían ser:

var dic = db
        .Table
        .Select(p => new { p.Key, p.Value })
        .AsEnumerable()
        .ToDictionary(k=> k.Key, v => v.Value);

9
2017-10-28 23:07



¿Por qué crearías un objeto anónimo para cada elemento de la tabla solo para convertirlo?

Simplemente podría usar algo como: IDictionary<string, string> dic = db.Table.ToDictionary(row => row.Key, row => row.Value); Es posible que deba incluir una llamada AsEnumerable () entre Table y ToDictionary (). No sé el tipo exacto de db.Table.


También corrija la primera muestra, su segunda variable de bucle no coincide con la declaración y el uso.


1
2018-01-18 19:46