Как правило, оператор join возвращает последовательность, состоящую из дан ных, полученных из двух источников. Следовательно, с помощью оператора join мож но сформировать новый список, состоящий из элементов, полученных из двух разных источников данных. Это дает возможность организовать данные по-новому.
Ниже приведена программа, в которой создается класс 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 для описания связи, по которой из двух разных источников данных выбираются наимено вания товаров, когда их порядковые номера совпадают.
И наконец, оператор select возвращает объект класса Temp, содержащий наиме нование товара и состояние его запасов на складе. select new Temp(item.Name, entry.InStock);
Таким образом, последовательность результатов, получаемая по данному запросу, состоит из объектов типа Temp.