El contenido de este modulo fueron
DictionaryTryGet
LiqQuery
Distinct
From,select, where
OrderBy,groupBy
Introducción
Todo lo que aprenderás sobre C#
Etapa 5 – POO reutilicemos nuestro código
Reutilizando nuestro Código
Herencia
Polimorfismo
Problemas del polimorfismo
Lista de Objetos polimórfica
Utilizando ToString para mejorar la depuración
Etapa 6- Ajustes y funcionalidad
Implementación de interfaces
Uso de interfaces
Creación y uso de regiones
Etapa 7 – Preparando información para nuestros reportes
Parámetros de salida
Probando funcionalidades de parámetros de salida
Sobrecargas de métodos
Listas de solo Lectura
Diccionario Polimórfico
Implementación de un diccionario
Uso de numeraciones en diccionario
Introduciendo datos en un diccionario
Recorrido de datos en diccionario
Impresión de objetos de un diccionario
Uso de la sentencia switch
Eventos
Recapitulemos
Etapa 8 – Consultas
Creación del reporteador
Extrayendo datos de un diccionario de manera segura
Aprendiendo linq
Sentencia where de linq
Divide y triunfarás
Agrupamientos en linq
Tipos anónimos en consultas linq
Segundo Reto
Etapa 9 – Creando una UI de Consola
Excepciones y cascadeo de excepciones
Sentencia finally
Reto final
Cierre del curso
No tienes acceso a esta clase
¡Continúa aprendiendo! Únete y comienza a potenciar tu carrera
No se trata de lo que quieres comprar, sino de quién quieres ser. Invierte en tu educación con el precio especial
Antes: $249
Paga en 4 cuotas sin intereses
Termina en:
Juan Carlos Ruiz
Aportes 14
Preguntas 3
El contenido de este modulo fueron
DictionaryTryGet
LiqQuery
Distinct
From,select, where
OrderBy,groupBy
que despistado para programar! jaja
Que no se supone que esos reportes como lo son las asignaciones, alumnos por asignacion y sus promedios deberia ser delegada a la Base de Datos, ya que como se vio en el uso de funciones Linq estas facilitan enormemente la carga de logica, y estas funciones/reportes los crearia con gran facilidad en la base de datos
La serie de Linq fue muy desordenada, se saltan muchos conceptos. Group by se explica por encima y se usa bastante, Juan Carlos es muy pro en conocimiento pero le falta organizar los ejemplos y ejercicios.
Para mí fue más fácil hacer el agrupamiento por nombre en lugar del Id, me funciona perfecto y así me evito hacer tipos anónimos en el agrupamiento y bla bla de mas xD
public Dictionary<string, Object> ExtractAverage()
{
var outAverage = new Dictionary<string, Object>();
var evalsBysubjectDic = ExtractEvaluationsBySubject();
foreach (var keyValPair in evalsBysubjectDic)
{
//agrupa en evalsGroup las evaluaciones por nombre de alumno
var dummy = from eval in keyValPair.Value
group eval by eval.studentBelong.name
into evalsGroup select new
{
name= evalsGroup.Key,
average =evalsGroup.Average(evaluation => evaluation.value)
};
//^^^ saca el promedio del grupo de evaluaciones
}
return outAverage;
}
Como asocia la funcion lambda la variable evaluacion, con las evaluaciones del alumno cunado se hace el promedio.
Linq, excelente herramienta para las consultas de datos en memoria minimizando la carga de grandes consultas a la base de datos.
😎
Interesante
Al principio cuesta entenderlo. Recomiendo ver el video más de 1 vez para entenderlo bien.
Cuando hace el select, devuelve un innumerable, y de paso lo usa para crear un tipo anónimo y average recive uno a uno esos elementos del innumerable y les saca el float
De la misma forma que uno a uno va sacando del key el unique o nombre (dependiendo a que le asignasteis la key)
este agrupamiento y los tipos anónimos son útiles cuando la BD puede que sea diferente a SQL server.
Entiendo que el objetivo de la clase era el manejo del LinQ, pero creo que se debió haber hecho un ejemplo mas y aplicado a la realidad. No creo que para sacar un campo calculado se deba crear una entidad. Debe de haber una forma mas sencilla para reportar datos calculados.
Creo que al agrupar por nombre seguimos obteniendo la misma cantidad de estudiantes por materia ya que si bien el nombre de algunos alumnos se repite son distintos por que tienen diferente id. Esto por la generacion aleatoria de alumnos. Quiza si se agrupa por nombre tendremos el resultado esperado.
¿Quieres ver más aportes, preguntas y respuestas de la comunidad?