Читаем C# 4.0: полное руководство полностью

    // Отсортировать эти сведения сначала по имени, затем

    //по фамилии и, наконец, по остатку на счете,

    var accInfo = from acc in accounts

                  orderby acc.LastName, acc.FirstName, acc.Balance

                  select acc;

    Console.WriteLine("Счета в отсортированном порядке: ");

    string str = "";

    // Выполнить запрос и вывести его результаты,

    foreach (Account acc in accInfo) {

      if (str != acc.FirstName) {

        Console.WriteLine();

        str = acc.FirstName;

      }

      Console.WriteLine("{0}, {1}\tHoMep счета: {2}, {3}",

                                acc.LastName, acc.FirstName,

                                acc.AccountNumber, acc.Balance);

      //acc.LastName, acc.FirstName,

      //acc.AccountNumber, acc.Balance);

    }

    Console.WriteLine();

  }

}

Ниже приведен результат выполнения этой программы.

Счета в отсортированном порядке:

Джонс, Дженни   Номер счета: 108СК, $10.98

Джонс, Ральф    Номер счета: 434СК,    ($123.32)

Джонс, Ральф    Номер счета: 454ММ,     $987.13

Джонс, Ральф    Номер счета: 436CD,   $1,923.85

Краммер, Бетти  Номер счета: 968ММ,   $5,146.67

Краммер, Тед    Номер счета: 897CD,   $3,223.19

Смит, Альберт   Номер счета: 445СК,    ($213.67)

Смит, Карл      Номер счета: 078CD,  $15,345.99

Смит, Сара      Номер счета: 843СК,     $345.00

Смит, Сара      Номер счета: 543ММ,   $5,017.40

Смит, Сара      Номер счета: 547CD,  $34,955.79

Смит, Том       Номер счета: 132СК,     $100.23

Смит, Том       Номер счета: 132CD,  $10,000.00

Внимательно проанализируем оператор orderby в следующем запросе из приведенной выше программы.

var accInfo = from асс in accounts

       orderby acc.LastName, acc.FirstName,

       acc.Balance

       select acc;

Сортировка результатов этого запроса осуществляется следующим образом. Сначала результаты сортируются по фамилии, затем элементы с одинаковыми фамилиями сортируются по имени. И наконец, группы элементов с одинаковыми фамилиями и именами сортируются по остатку на счете. Именно поэтому список счетов вкладчиков по фамилии Джонс выглядит так.

Джонс, Дженни   Номер счета: 108СК,    $10.98

Джонс, Ральф    Номер счета: 434СК,  ($123.32)

Джонс, Ральф    Номер счета: 454ММ,   $987.13

Джонс, Ральф    Номер счета: 436CD, $1,923.85

Как показывает результат выполнения данного запроса, список счетов отсортирован сначала по фамилии, затем по имени и, наконец, по остатку на счете.

Используя несколько критериев, можно изменить на обратный порядок любой сортировки с помощью ключевого слова descending. Например, результаты следующего запроса будут выведены по убывающей остатков на счетах.

var accInfo = from acc in accounts

            orderby x.LastName, x.FirstName, x.Balance descending select acc;

В этом случае список счетов вкладчиков по фамилии Джонс будет выглядеть так, как показано ниже.

Джонс, Дженни    Номер счета: 108СК,     $10.98

Джонс, Ральф     Номер счета: 436CD,  $1,923.85

Джонс, Ральф     Номер счета: 454ММ,    $987.13

Джонс, Ральф     Номер счета: 434СК,   ($123.32)

Как видите, теперь счета вкладчика по фамилии Ральф Джонс выводятся по убывающей: от наибольшей до наименьшей суммы остатка на счете.

<p>Подробное рассмотрение оператора select</p>

Оператор select определяет конкретный тип элементов, получаемых по запросу. Ниже приведена его общая форма.

select выражение

Перейти на страницу:

Похожие книги

1001 совет по обустройству компьютера
1001 совет по обустройству компьютера

В книге собраны и обобщены советы по решению различных проблем, которые рано или поздно возникают при эксплуатации как экономичных нетбуков, так и современных настольных моделей. Все приведенные рецепты опробованы на практике и разбиты по темам: аппаратные средства персональных компьютеров, компьютерные сети и подключение к Интернету, установка, настройка и ремонт ОС Windows, работа в Интернете, защита от вирусов. Рассмотрены не только готовые решения внезапно возникающих проблем, но и ответы на многие вопросы, которые возникают еще до покупки компьютера. Приведен необходимый минимум технических сведений, позволяющий принять осознанное решение.Компакт-диск прилагается только к печатному изданию книги.

Юрий Всеволодович Ревич

Программирование, программы, базы данных / Интернет / Компьютерное «железо» / ОС и Сети / Программное обеспечение / Книги по IT
Разработка приложений в среде Linux. Второе издание
Разработка приложений в среде Linux. Второе издание

Книга известных профессионалов в области разработки коммерческих приложений в Linux представляет СЃРѕР±РѕР№ отличный справочник для широкого круга программистов в Linux, а также тех разработчиков на языке С, которые перешли в среду Linux из РґСЂСѓРіРёС… операционных систем. РџРѕРґСЂРѕР±но рассматриваются концепции, лежащие в основе процесса создания системных приложений, а также разнообразные доступные инструменты и библиотеки. Среди рассматриваемых в книге вопросов можно выделить анализ особенностей применения лицензий GNU, использование СЃРІРѕР±одно распространяемых компиляторов и библиотек, системное программирование для Linux, а также написание и отладка собственных переносимых библиотек. Р

Майкл К. Джонсон , Эрик В. Троан

Программирование, программы, базы данных
Adobe InDesign CS3
Adobe InDesign CS3

Книга посвящена верстке и макетированию в программе Adobe InDesign CS3. Помимо того что в ней описываются возможности программы, рассматриваются также принципы и традиции верстки, приводятся примеры решения типичных задач. Все это позволит читателю не только овладеть богатым инструментарием программы, но и грамотно применять его.Материал книги разделен на логические части: теоретические сведения, инструментарий программы, решение задач, – а также рассчитан на два уровня подготовки читателей – начинающих и опытных пользователей, что выгодно отличает книгу от других изданий. Это позволит применять ее как новичкам для знакомства с программой, так и пользователям со стажем для пополнения своих знаний.

Владимир Гавриилович Завгородний , Владимир Завгородний

Программирование, программы, базы данных / Программное обеспечение / Книги по IT