Как запросить LIST, используя linq

предположим, если я добавлю экземпляр класса person в список, а затем мне нужно запросить список, используя linq.

List lst=new List();
lst.add(new person{ID=1,Name="jhon",salaty=2500});
lst.add(new person{ID=2,Name="Sena",salaty=1500});
lst.add(new person{ID=3,Name="Max",salaty=5500});
lst.add(new person{ID=4,Name="Gen",salaty=3500});

теперь я хочу запросить приведенный выше список с помощью linq. пожалуйста, назовите меня примером кода.

Ответы

Ответ 1

Я также предлагаю LinqPad как удобный способ справиться с Linq для продвинутых и начинающих.

Пример:
enter image description here

Ответ 2

Ну, код, который вы указали, недействителен для начала - List является общим типом и имеет метод Add вместо Add и т.д.

Но вы могли бы сделать что-то вроде:

List<Person> list = new List<Person>
{
    new person{ID=1,Name="jhon",salaty=2500},
    new person{ID=2,Name="Sena",salaty=1500},
    new person{ID=3,Name="Max",salaty=5500}.
    new person{ID=4,Name="Gen",salaty=3500}
};

// The "Where" LINQ operator filters a sequence
var highEarners = list.Where(p => p.salaty > 3000);

foreach (var person in highEarners)
{
    Console.WriteLine(person.Name);
}

Если вы хотите узнать подробности о том, что делают все операторы LINQ, и как они могут быть реализованы в LINQ to Objects, вы можете быть заинтересованы в моем Edulinq блоге.

Ответ 3

var persons = new List<Person>
    {
        new Person {ID = 1, Name = "jhon", Salary = 2500},
        new Person {ID = 2, Name = "Sena", Salary = 1500},
        new Person {ID = 3, Name = "Max", Salary = 5500},
        new Person {ID = 4, Name = "Gen", Salary = 3500}
    };

var acertainperson = persons.Where(p => p.Name == "jhon").First();
Console.WriteLine("{0}: {1} points",
    acertainperson.Name, acertainperson.Salary);

jhon: 2500 points

var doingprettywell = persons.Where(p => p.Salary > 2000);
            foreach (var person in doingprettywell)
            {
                Console.WriteLine("{0}: {1} points",
                    person.Name, person.Salary);
            }

jhon: 2500 points
Max: 5500 points
Gen: 3500 points

        var astupidcalc = from p in persons
                          where p.ID > 2
                          select new
                                     {
                                         Name = p.Name,
                                         Bobos = p.Salary*p.ID,
                                         Bobotype = "bobos"
                                     };
        foreach (var person in astupidcalc)
        {
            Console.WriteLine("{0}: {1} {2}",
                person.Name, person.Bobos, person.Bobotype);
        }

Max: 16500 bobos
Gen: 14000 bobos

Ответ 4

Поскольку вы не указали на то, что хотите, вот ссылка на 101 образец LINQ, который использует все различные методы LINQ: 101 LINQ Образцы

Кроме того, вы действительно должны действительно изменить свой List на список сильно типов (List<T>) и правильно определить T и добавить экземпляры T в свой список. Это действительно упростит запросы, так как вам не нужно все время бросать.