Книга: C# 4.0: полное руководство

Отбор запрашиваемых значений с помощью оператора where

Отбор запрашиваемых значений с помощью оператора where

Как пояснялось выше, оператор where служит для отбора данных, возвращаемых по запросу. В предыдущих примерах этот оператор был продемонстрирован в своей простейшей форме, в которой для отбора данных используется единственное условие. Однако для более тщательного отбора данных можно задать несколько условий и, в частности, в нескольких операторах where. В качестве примера рассмотрим следующую программу, в которой из массива выводятся только те значения, которые положительны и меньше 10.

// Использовать несколько операторов where.
using System;
using System.Linq;
class TwoWheres {
  static void Main() {
    int [ ] nums = { 1, -2, 3, -3, 0, -8, 12, 19, 6, 9, 10 };
    // Сформировать запрос на получение положительных значений меньше 10.
    var posNums = from n in nums where n > 0 where n < 10 select n;
    Console.Write("Положительные значения меньше 10: ");
    // Выполнить запрос и вывести его результаты.
    foreach(int i in posNums) Console.Write (i + " ");
    Console.WriteLine();
  }
}

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

Положительные значения меньше 10: 1 3 6 9

Как видите, по данному запросу извлекаются только положительные значения меньше. 10. Этот результат достигается благодаря двум следующим операторам where.

where n > 0 where n < 10

Условие в первом операторе where требует, чтобы элемент массива был больше нуля. А условие во втором операторе where требует, чтобы элемент массива был меньше 10. Следовательно, запрашиваемый элемент массива должен находиться в пределах от 1 до 9 (включительно), чтобы удовлетворять обоим условиям.

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

var posNums = from n in nums
         where n>0 && n<10 select n;

Как правило, в условии оператора where разрешается использовать любое допустимое в C# выражение, дающее булев результат. Например, в приведенной ниже программе определяется массив символьных строк. В ряде этих строк содержатся адреса Интернета. По запросу в переменой netAddrs извлекаются только те строки, которые содержат более четырех символов и оканчиваются на ".net". Следовательно, по данному запросу обнаруживаются строки, содержащие адреса Интернета с именем . net домена самого верхнего уровня.

// Продемонстрировать применение еще одного оператора where.
using System;
using System.Linq;
class WhereDemo2 {
  static void Main() {
    string[] strs = { ".com", ".net", "hsNameA.com",
                  "hsNameB.net", "test", ".network",
                  "hsNameC.net", "hsNameD.com" };
    // Сформировать запрос на получение адресов
    // Интернета, оканчивающихся на .net.
    var netAddrs = from addr in strs
         where addr.Length > 4 && 
           addr.EndsWith(".net", StringComparison.Ordinal)
           select addr;
    // Выполнить запрос и вывести его результаты.
    foreach(var str in netAddrs) Console.WriteLine(str);
  }
}

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

hsNameB.net
hsNameC.net

Обратите внимание на то, что в операторе where данной программы используется один из методов обработки символьных строк под названием EndsWith(). Он возвращает логическое значение true, если вызывающая его строка оканчивается последовательностью символов, указываемой в качестве аргумента этого метода.

Оглавление книги


Генерация: 1.202. Запросов К БД/Cache: 3 / 0
поделиться
Вверх Вниз