committed by
Christopher McCormack
parent
32a92baff4
commit
ca0d64ee3e
@ -1,7 +1,8 @@
|
|||||||
---
|
---
|
||||||
title: LINQ
|
title: LINQ
|
||||||
localeTitle: LINQ
|
localeTitle: LINQ
|
||||||
---
|
---
|
||||||
|
# LINQ (Language Integrated Query)
|
||||||
|
|
||||||
LINQ (Language Integrated Query) es un modelo y metodología de programación de Microsoft que esencialmente agrega capacidades de consulta formales a los lenguajes de programación basados en Microsoft .NET. LINQ ofrece una sintaxis compacta, expresiva e inteligible para manipular datos. El valor real de LINQ proviene de su capacidad para aplicar la misma consulta a una base de datos SQL, un DataSet, una lista, un diccionario, etc.
|
LINQ (Language Integrated Query) es un modelo y metodología de programación de Microsoft que esencialmente agrega capacidades de consulta formales a los lenguajes de programación basados en Microsoft .NET. LINQ ofrece una sintaxis compacta, expresiva e inteligible para manipular datos. El valor real de LINQ proviene de su capacidad para aplicar la misma consulta a una base de datos SQL, un DataSet, una lista, un diccionario, etc.
|
||||||
|
|
||||||
@ -23,28 +24,28 @@ var fruits = new List<Fruit>() {
|
|||||||
Entonces podemos hacer cosas como:
|
Entonces podemos hacer cosas como:
|
||||||
|
|
||||||
```csharp
|
```csharp
|
||||||
```csharp
|
// Obtener el nombre de la primer fruta
|
||||||
var firstName = fruits.Select(f => f.Name).First(); // Orange
|
var firstName = fruits.Select(f => f.Name).First(); // Orange
|
||||||
|
|
||||||
|
// Conteo de las frutas rojas
|
||||||
var qntRed = fruits.Where(Color == "Red").Count(); // 2
|
var qntRed = fruits.Where(Color == "Red").Count(); // 2
|
||||||
|
|
||||||
|
// Lista de las frutas amarillas
|
||||||
var yellowFruits = fruits.Where(f => f.Color == "Yellow").ToList(); // { Pineapple, Mango }
|
var yellowFruits = fruits.Where(f => f.Color == "Yellow").ToList(); // { Pineapple, Mango }
|
||||||
|
|
||||||
|
// Ordenar la lista de mayor a menor cantidad
|
||||||
var orderedFruits = fruits.OrderByDescending(f => f.Quantity).ToList(); // {Grape, Strawberry, Orange, Apple, Mango, Pineapple}
|
var orderedFruits = fruits.OrderByDescending(f => f.Quantity).ToList(); // {Grape, Strawberry, Orange, Apple, Mango, Pineapple}
|
||||||
|
|
||||||
|
// Suma de las cantidades de las frutas
|
||||||
var quantity = fruits.Sum(f => f.Quantity); // 53
|
var quantity = fruits.Sum(f => f.Quantity); // 53
|
||||||
|
|
||||||
|
// Consultar si hay frutas verdes
|
||||||
var hasGreen = fruits.Any(f => f.Color == "Green"); // false
|
var hasGreen = fruits.Any(f => f.Color == "Green"); // false
|
||||||
|
|
||||||
|
// Agrupar frutas por color en un diccionario
|
||||||
var fruitsByColor = fruits.GroupBy(g => g.Color).ToDictionary(k => k.Key, v => v.ToList()); // Dictionary of list of fruits by color
|
var fruitsByColor = fruits.GroupBy(g => g.Color).ToDictionary(k => k.Key, v => v.ToList()); // Dictionary of list of fruits by color
|
||||||
|
|
||||||
|
// Las operaciones linq pueden ser concatenadas y no se realizan hasta que la informacion es requerida
|
||||||
var logs = new List<Log>;
|
var logs = new List<Log>;
|
||||||
|
|
||||||
if (filterBySeverity)
|
if (filterBySeverity)
|
||||||
|
Reference in New Issue
Block a user