ObjectQuery<T>.Distinct Metoda
Definicja
Ważne
Niektóre informacje odnoszą się do produktu w wersji wstępnej, który może zostać znacząco zmodyfikowany przed wydaniem. Firma Microsoft nie udziela żadnych gwarancji, jawnych lub domniemanych, w odniesieniu do informacji podanych w tym miejscu.
Ogranicza zapytanie do unikatowych wyników.
public:
System::Data::Objects::ObjectQuery<T> ^ Distinct();
public System.Data.Objects.ObjectQuery<T> Distinct ();
member this.Distinct : unit -> System.Data.Objects.ObjectQuery<'T>
Public Function Distinct () As ObjectQuery(Of T)
Zwraca
Nowe ObjectQuery<T> wystąpienie, które jest równoważne oryginalnemu wystąpieniu z zastosowanym poleceniem SELECT DISTINCT .
Przykłady
W tym przykładzie użyto UnionAll metody do utworzenia nowego ObjectQuery<T> obiektu. Następnie wywołuje Distinct nowy ObjectQuery<T> obiekt, aby uzyskać unikatowe wyniki tego zapytania.
int productID = 100;
using (AdventureWorksEntities context =
new AdventureWorksEntities())
{
string queryString =
@"SELECT VALUE product FROM AdventureWorksEntities.Products
AS product WHERE product.ProductID < @productID";
ObjectQuery<Product> productQuery =
new ObjectQuery<Product>(queryString,
context, MergeOption.NoTracking);
ObjectQuery<Product> productQuery2 =
new ObjectQuery<Product>(queryString,
context, MergeOption.NoTracking);
ObjectQuery<Product> productQuery3 =
productQuery.UnionAll(productQuery2);
productQuery3.Parameters.Add(new ObjectParameter("productID", productID));
Console.WriteLine("Result of UnionAll");
Console.WriteLine("------------------");
// Iterate through the collection of Product items,
// after the UnionAll method was called on two queries.
foreach (Product result in productQuery3)
{
Console.WriteLine("Product Name: {0}", result.ProductID);
}
ObjectQuery<Product> productQuery4 = productQuery3.Distinct();
Console.WriteLine("\nResult of Distinct");
Console.WriteLine("------------------");
// Iterate through the collection of Product items.
// after the Distinct method was called on a query.
foreach (Product result in productQuery4)
Console.WriteLine("Product Name: {0}", result.ProductID);
}
Uwagi
Ta metoda konstruktora zapytań zwraca wystąpienie, które jest równoważne oryginalnemu ObjectQuery<T> zapytaniu z zastosowanym poleceniem SELECT DISTINCT .
Nie DISTINCT
można zastosować operatora do obiektu, który zawiera mapowanie do kolumny innej niż porównywalna w źródle danych (na przykład ntekst).