Kniga-Online.club
» » » » Герберт Шилдт - C# 4.0: полное руководство

Герберт Шилдт - C# 4.0: полное руководство

Читать бесплатно Герберт Шилдт - C# 4.0: полное руководство. Жанр: Программирование издательство -, год 2004. Так же читаем полные версии (весь текст) онлайн без регистрации и SMS на сайте kniga-online.club или прочесть краткое содержание, предисловие (аннотацию), описание и ознакомиться с отзывами (комментариями) о произведении.
Перейти на страницу:

          select ch;

    Console.WriteLine("Отдельные символы, отсортированные по порядку:");

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

    foreach(char с in chrs) Console.Write(с + " ");

    Console.WriteLine();

  }

}

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

Отдельные символы, отсортированные по порядку:

a a a a a b e g h l m m p t

Обратите внимание в данном примере программы на то, что в операторе let переменной chrArray присваивается ссылка на массив, возвращаемый методом str.ToCharArray().

let chrArray = str.ToCharArray()

После оператора let переменная chrArray может использоваться в остальных операторах, составляющих запрос. А поскольку все массивы в C# преобразуются в тип IEnumerable<T>, то переменную chrArray можно использовать в качестве источника данных для запроса во втором, вложенном операторе from. Именно это и происходит в рассматриваемом здесь примере, где вложенный оператор from служит для перечисления в массиве отдельных символов, которые затем сортируются по нарастающей и возвращаются в виде конечного результата.

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

var webAddrs = from addr in websites

         let idx = addr.LastIndexOf('.') where idx != -1

         group addr by addr.Substring(idx)

         into ws where ws.Count() > 2

         select ws;

В этом варианте индекс последнего вхождения символа точки в строку присваивается переменной idx. Данное значение затем используется в методе Substring(). Благодаря этому исключается необходимость дважды искать символ точки в строке.

Объединение двух последовательностей с помощью оператора join

Когда приходится иметь дело с базами данных, то зачастую требуется формировать последовательность, увязывающую данные из разных источников. Например, в Интернет-магазине может быть организована одна база данных, связывающая наименование товара с его порядковым номером, и другая база данных, связывающая порядковый номер товара с состоянием его запасов на складе. В подобной ситуации может возникнуть потребность составить список, в котором состояние запасов товаров на складе отображается по их наименованию, а не порядковому номеру. Для этой цели придется каким-то образом "увязать" данные из двух разных источников (баз данных). И это нетрудно сделать с помощью такого средства LINQ, как оператор join.

Ниже приведена общая форма оператора join (совместно с оператором from).

from переменная_диапазона_А in источник_данных_А

 join переменная_диапазона_В in источник_данных_В

   on переменная_диапазона_А.свойство equals переменная_диапазона_В.свойство

Применяя оператор join, следует иметь в виду, что каждый источник должен содержать общие данные, которые можно сравнивать. Поэтому в приведенной выше форме этого оператора источник_данных_А и источник_данных_В должны иметь нечто общее, что подлежит сравнению. Сравниваемые элементы данных указываются в части on данного оператора. Поэтому если переменная_диапазона_А. свойство и переменная_диапазона_А. свойство равны, то эти элементы данных "увязываются" успешно. По существу, оператор join выполняет роль своеобразного фильтра, отбирая только те элементы данных, которые имеют общее значение.

Как правило, оператор join возвращает последовательность, состоящую из данных, полученных из двух источников. Следовательно, с помощью оператора jоin можно сформировать новый список, состоящий из элементов, полученных из двух разных источников данных. Это дает возможность организовать данные по-новому.

Ниже приведена программа, в которой создается класс Item, инкапсулирующий наименование товара и его порядковый номер. Затем в этой программе создается еще один класс InStockStatus, связывающий порядковый номер товара с булевым свойством, которое указывает на наличие или отсутствие товара на складе. И наконец, в данной программе создается класс Temp с двумя полями: строковым (string) и булевым (bool). В объектах этого класса будут храниться результаты запроса. В этом запросе оператор join используется для получения списка, в котором наименование товара связывается с состоянием его запасов на складе.

// Продемонстрировать применение оператора join.

using System;

using System.Linq;

// Класс, связывающий наименование товара с его порядковым номером,

class Item {

  public string Name { get; set; }

  public int ItemNumber { get; set; }

  public Item(string n, int inum) {

    Name = n;

    ItemNumber = inum;

  }

}

// Класс, связывающий наименование товара

// с состоянием его запасов на складе,

class InStockStatus {

  public int ItemNumber { get; set; }

  public bool InStock { get; set; }

  public InStockStatus (int n, bool b) {

    ItemNumber = n;

    InStock = b;

  }

}

// Класс, инкапсулирующий наименование товара и

// состояние его запасов на складе,

class Temp {

  public string Name { get; set; }

  public bool InStock { get; set; }

  public Temp(string n, bool b) {

    Name = n;

    InStock = b;

  }

}

class JoinDemo {

  static void Main() {

    Item[] items = {

      new Item("Кусачки", 1424), new Item("Тиски", 7892),

      new Item("Молоток", 8534), new Item("Пила", 6411)

    };

    InStockStatus[] statusList = {

      new InStockStatus(1424, true),

      new InStockStatus(7892, false),

      new InStockStatus(8534, true),

      new InStockStatus(6411, true)

    };

    // Сформировать запрос, объединяющий объекты классов Item

    //и InStockStatus для составления списка наименований товаров

    // и их наличия на складе. Обратите внимание на формирование

    // последовательности объектов класса Temp,

    var inStockList = from item in items

        join entry in statusList

          on item.ItemNumber equals entry.ItemNumber

        select new Temp(item.Name, entry.InStock);

    Console.WriteLine("ТоварtНаличиеn");

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

    foreach(Temp t in inStockList)

      Console.WriteLine("{0}t{1}", t.Name, t.InStock);

  }

}

Эта программа дает следующий результат

Товар    Наличие

Кусачки  True

Тиски    False

Молоток  True

Пила     True

Для того чтобы стал понятнее принцип действия оператора join, рассмотрим каждую строку запроса из приведенной выше программы по порядку. Этот запрос начинается, как обычно, со следующего оператора from.

var inStockList = from item in items

В этом операторе указывается переменная диапазона item для источника данных items, который представляет собой массив объектов класса Item. В классе Item инкапсулируются наименование товара и порядковый номер товара, хранящегося на складе.

Далее следует приведенный ниже оператор join.

join entry in statusList

  on item.ItemNumber equals entry.ItemNumber

В этом операторе указывается переменная диапазона entry для источника данных statusList, который представляет собой массив объектов класса InStockStatus, связывающего порядковый номер товара с состоянием его запасов на складе. Следовательно, у массивов items и statusList имеется общее свойство: порядковый номер товара. Именно это свойство используется в части on/equals оператора join для описания связи, по которой из двух разных источников данных выбираются наименования товаров, когда их порядковые номера совпадают.

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

Герберт Шилдт читать все книги автора по порядку

Герберт Шилдт - все книги автора в одном месте читать по порядку полные версии на сайте онлайн библиотеки kniga-online.club.


C# 4.0: полное руководство отзывы

Отзывы читателей о книге C# 4.0: полное руководство, автор: Герберт Шилдт. Читайте комментарии и мнения людей о произведении.


Уважаемые читатели и просто посетители нашей библиотеки! Просим Вас придерживаться определенных правил при комментировании литературных произведений.

  • 1. Просьба отказаться от дискриминационных высказываний. Мы защищаем право наших читателей свободно выражать свою точку зрения. Вместе с тем мы не терпим агрессии. На сайте запрещено оставлять комментарий, который содержит унизительные высказывания или призывы к насилию по отношению к отдельным лицам или группам людей на основании их расы, этнического происхождения, вероисповедания, недееспособности, пола, возраста, статуса ветерана, касты или сексуальной ориентации.
  • 2. Просьба отказаться от оскорблений, угроз и запугиваний.
  • 3. Просьба отказаться от нецензурной лексики.
  • 4. Просьба вести себя максимально корректно как по отношению к авторам, так и по отношению к другим читателям и их комментариям.

Надеемся на Ваше понимание и благоразумие. С уважением, администратор kniga-online.


Прокомментировать
Подтвердите что вы не робот:*
Подтвердите что вы не робот:*