следует выбирать. Например, по запросу списка рассылки может быть получена лишь фамилия адресата вместо его полного адреса. Обратите внимание на то, что операторselectзавершается точкой с запятой, поскольку это последний оператор в запросе. А другие его операторы не оканчиваются точкой с запятой.
Итак, переменная запросаposNumsсоздана, но результаты запроса пока еще не получены. Дело в том, что сам запрос определяет лишь ряд конкретных правил, а результаты будут только после выполнения запроса. Кроме того, один и тот же запрос может быть выполнен два раза или больше, причем с разными результатами, если в промежутке между последовательно производимыми попытками выполнить один и тот же запрос изменяется базовый источник данных. Поэтому одного лишь объявления переменной запросаposNumsсовершенно недостаточно для того, чтобы она содержала результаты запроса.
Для выполнения запроса в данном примере программы организуется следующий цикл.
foreach(int i in posNums) Console.WriteLine(i + " ");
В этом цикле переменнаяposNumsуказывается в качестве коллекции, к которой происходит обращение на каждом шаге цикла. В циклеforeachсоблюдаются правила, определенные в запросе и доступные по ссылке из переменнойposNums.На каждом шаге цикла возвращается очередной элемент, полученный из массива. Этот процесс завершается, когда запрашиваемых элементов в массиве больше не обнаружено. В данном примере типintпеременной шага циклаiуказывается явно, поскольку по запросу извлекаются элементы именно этого типа. Явное указание типа переменной шага цикла вполне допустимо в тех случаях, когда заранее известен тип значения, выбираемого по запросу. Но в более сложных случаях оказывается проще, а иногда даже нужно, указывать тип переменной шага цикла неявным образом с помощью ключевого словаvar.
Неоднократное выполнение запросов