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

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

Адреса электронной почты:

[email protected]

[email protected]

[email protected]

Обратите особое внимание на следующий оператор select.

select entry.Address;

Вместо полного значения переменной диапазона этот оператор возвращает лишь его адресную часть (Address). Это означает, что по данному запросу возвращается последовательность символьных строк, а не объектов типа EmailAddress. Именно поэтому переменная s указывается в цикле foreach как string. Ведь как пояснялось ранее, тип последовательности результатов, возвращаемых по запросу, определяется типом значения, возвращаемым оператором select.

Одной из самых эффективных для оператора select является возможность возвращать последовательность результатов, содержащую элементы данных, формируемые во время выполнения запроса. В качестве примера рассмотрим еще одну программу. В ней определяется класс ContactInfo, в котором хранится имя, адрес электронной почты и номер телефона адресата. Кроме того, в этой программе определяется класс EmailAddress, использовавшийся в предыдущем примере. В методе Main() создается массив объектов типа ContactInfo, а затем объявляется запрос, в котором источником данных служит этот массив, но возвращаемая последовательность результатов содержит объекты типа EmailAddress. Таким образом, типом последовательности результатов, возвращаемой оператором select, является класс EmailAddress, а не класс ContactInfo, причем его объекты создаются во время выполнения запроса.

// Использовать запрос для получения последовательности объектов

// типа EmailAddresses из списка объектов типа ContactInfo.

using System;

using System.Linq;

class ContactInfo {

  public string Name { get; set; }

  public string Email { get; set; }

  public string Phone { get; set; }

  public ContactInfo(string n, string a, string p) {

    Name = n;

    Email = a;

    Phone = p;

  }

}

class EmailAddress {

  public string Name { get; set; }

  public string Address { get; set; }

  public EmailAddress(string n, string a) {

    Name = n;

    Address = a;

  }

}

class SelectDemo3 {

  static void Main() {

    ContactInfo[] contacts = {

      new ContactInfo("Герберт", "[email protected]", "555-1010"),

      new ContactInfo("Том", "[email protected]", "555-1101"),

      new ContactInfo("Capa", "[email protected]", "555-0110")

    };

    // Сформировать запрос на получение

    // списка объектов типа EmailAddress.

    var emailList = from entry in contacts

           select new EmailAddress(entry.Name, entry.Email);

    Console.WriteLine("Список адресов электронной почты:");

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

    foreach(EmailAddress e in emailList)

      Console.WriteLine(" {0}: {1}", e.Name, e.Address );

  }

}

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

Список адресов электронной почты:

Герберт: [email protected]

Том: [email protected]

Сара: [email protected]

Обратите особое внимание в данном запросе на следующий оператор select.

select new EmailAddress(entry.Name, entry.Email);

В этом операторе создается новый объект типа EmailAddress, содержащий имя и адрес электронной почты, получаемые из объекта типа ContactInfo, хранящегося в массиве contacts. Но самое главное, что новые объекты типа EmailAddress создаются в операторе select во время выполнения запроса.

<p>Применение вложенных операторов from</p>
Перейти на страницу:

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

1С: Бухгалтерия 8 с нуля
1С: Бухгалтерия 8 с нуля

Книга содержит полное описание приемов и методов работы с программой 1С:Бухгалтерия 8. Рассматривается автоматизация всех основных участков бухгалтерии: учет наличных и безналичных денежных средств, основных средств и НМА, прихода и расхода товарно-материальных ценностей, зарплаты, производства. Описано, как вводить исходные данные, заполнять справочники и каталоги, работать с первичными документами, проводить их по учету, формировать разнообразные отчеты, выводить данные на печать, настраивать программу и использовать ее сервисные функции. Каждый урок содержит подробное описание рассматриваемой темы с детальным разбором и иллюстрированием всех этапов.Для широкого круга пользователей.

Алексей Анатольевич Гладкий

Программирование, программы, базы данных / Программное обеспечение / Бухучет и аудит / Финансы и бизнес / Книги по IT / Словари и Энциклопедии
1С: Управление торговлей 8.2
1С: Управление торговлей 8.2

Современные торговые предприятия предлагают своим клиентам широчайший ассортимент товаров, который исчисляется тысячами и десятками тысяч наименований. Причем многие позиции могут реализовываться на разных условиях: предоплата, отсрочка платежи, скидка, наценка, объем партии, и т.д. Клиенты зачастую делятся на категории – VIP-клиент, обычный клиент, постоянный клиент, мелкооптовый клиент, и т.д. Товарные позиции могут комплектоваться и разукомплектовываться, многие товары подлежат обязательной сертификации и гигиеническим исследованиям, некондиционные позиции необходимо списывать, на складах периодически должна проводиться инвентаризация, каждая компания должна иметь свою маркетинговую политику и т.д., вообщем – современное торговое предприятие представляет живой организм, находящийся в постоянном движении.Очевидно, что вся эта кипучая деятельность требует автоматизации. Для решения этой задачи существуют специальные программные средства, и в этой книге мы познакомим вам с самым популярным продуктом, предназначенным для автоматизации деятельности торгового предприятия – «1С Управление торговлей», которое реализовано на новейшей технологической платформе версии 1С 8.2.

Алексей Анатольевич Гладкий

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