Применяя оператор 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 = {

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

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