ObjectResult<T>.Dispose 方法
定义
执行与释放 (free)、释放 (release) 或重置资源关联的任务。Performs tasks associated with freeing, releasing, or resetting resources.
public:
override void Dispose();
public override void Dispose ();
override this.Dispose : unit -> unit
Public Overrides Sub Dispose ()
示例
本主题中的示例基于 " Microsoft SQL Server 产品示例:数据库"。The example in this topic is based on the Microsoft SQL Server Product Samples: Database. 该示例从 ObjectResult<T> 方法返回一个 Execute。The example returns an ObjectResult<T> from the Execute method. 然后,获取一个枚举器并循环访问查询结果。Then it gets an enumerator and iterates through the query results. 最后,释放枚举器和 ObjectResult<T> 对象。At the end, it releases the enumerator and the ObjectResult<T> object.
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();
}
}
}
Using context As New AdventureWorksEntities()
Dim query As ObjectSet(Of Product) = context.Products
Dim queryResults As ObjectResult(Of Product) = Nothing
Dim enumerator As System.Collections.IEnumerator = Nothing
Try
queryResults = query.Execute(MergeOption.AppendOnly)
' Get the enumerator.
enumerator = DirectCast(queryResults, System.Collections.IEnumerable).GetEnumerator()
' Iterate through the query results.
While enumerator.MoveNext()
Dim product As Product = DirectCast(enumerator.Current, Product)
Console.WriteLine("{0}", product.Name)
End While
' Dispose the enumerator
DirectCast(enumerator, IDisposable).Dispose()
Finally
' Dispose the query results and the enumerator.
If queryResults IsNot Nothing Then
queryResults.Dispose()
End If
If enumerator IsNot Nothing Then
DirectCast(enumerator, IDisposable).Dispose()
End If
End Try
End Using
注解
关闭包含查询结果的 DbDataReader。Closes the DbDataReader, which contains the results of the query.