Бөлісу құралы:


ObjectResult<T>.GetEnumerator Метод

Определение

Возвращает перечислитель для перебора результатов запроса.

public:
 virtual System::Collections::Generic::IEnumerator<T> ^ GetEnumerator();
public System.Collections.Generic.IEnumerator<T> GetEnumerator ();
abstract member GetEnumerator : unit -> System.Collections.Generic.IEnumerator<'T>
override this.GetEnumerator : unit -> System.Collections.Generic.IEnumerator<'T>
Public Function GetEnumerator () As IEnumerator(Of T)

Возвращаемое значение

Перечислитель, проходящий по результатам запроса.

Реализации

Примеры

В этом примере возвращается ObjectResult<T> из Execute метода . Затем возвращается перечислитель, и выполняется проход по результатам запроса. Наконец, он освобождает перечислитель и объект ObjectResult<T>.

using (AdventureWorksEntities context =
    new AdventureWorksEntities())
{
    ObjectSet<Product> query = context.Products;
    ObjectResult<Product> queryResults = null;

    System.Collections.IEnumerator enumerator = null;
    try
    {
        queryResults = query.Execute(MergeOption.AppendOnly);

        // Get the enumerator.
        enumerator = ((System.Collections.IEnumerable)queryResults).GetEnumerator();

        // Iterate through the query results.
        while (enumerator.MoveNext())
        {
            Product product = (Product)enumerator.Current;
            Console.WriteLine("{0}", product.Name);
        }
        // Dispose the enumerator
        ((IDisposable)enumerator).Dispose();
    }
    finally
    {
        // Dispose the query results and the enumerator.
        if (queryResults != null)
        {
            queryResults.Dispose();
        }
        if (enumerator != null)
        {
            ((IDisposable)enumerator).Dispose();
        }
    }
}

Комментарии

Когда перечислитель больше не нужен, его следует удалить. Использование инструкции foreach (For Each в Visual Basic) гарантирует, что перечислитель будет правильно удален после завершения итерации результатов.

Применяется к

См. также раздел