Queryable.Intersect 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.
Tworzy część wspólną zestawu dwóch sekwencji.
Przeciążenia
Intersect<TSource>(IQueryable<TSource>, IEnumerable<TSource>) |
Tworzy część wspólną zestawu dwóch sekwencji przy użyciu domyślnego modułu porównania równości do porównywania wartości. |
Intersect<TSource>(IQueryable<TSource>, IEnumerable<TSource>, IEqualityComparer<TSource>) |
Tworzy część wspólną zestawu dwóch sekwencji, używając określonej IEqualityComparer<T> wartości do porównania wartości. |
Intersect<TSource>(IQueryable<TSource>, IEnumerable<TSource>)
- Źródło:
- Queryable.cs
- Źródło:
- Queryable.cs
- Źródło:
- Queryable.cs
Tworzy część wspólną zestawu dwóch sekwencji przy użyciu domyślnego modułu porównania równości do porównywania wartości.
public:
generic <typename TSource>
[System::Runtime::CompilerServices::Extension]
static System::Linq::IQueryable<TSource> ^ Intersect(System::Linq::IQueryable<TSource> ^ source1, System::Collections::Generic::IEnumerable<TSource> ^ source2);
public static System.Linq.IQueryable<TSource> Intersect<TSource> (this System.Linq.IQueryable<TSource> source1, System.Collections.Generic.IEnumerable<TSource> source2);
static member Intersect : System.Linq.IQueryable<'Source> * seq<'Source> -> System.Linq.IQueryable<'Source>
<Extension()>
Public Function Intersect(Of TSource) (source1 As IQueryable(Of TSource), source2 As IEnumerable(Of TSource)) As IQueryable(Of TSource)
Parametry typu
- TSource
Typ elementów sekwencji wejściowych.
Parametry
- source1
- IQueryable<TSource>
Zwracana jest sekwencja, której różne elementy również pojawiają się w source2
obiekcie.
- source2
- IEnumerable<TSource>
Zwracana jest sekwencja, której różne elementy pojawiają się również w pierwszej sekwencji.
Zwraca
Sekwencja zawierająca część wspólną zestawu dwóch sekwencji.
Wyjątki
source1
lub source2
ma wartość null
.
Przykłady
W poniższym przykładzie kodu pokazano, jak użyć Intersect<TSource>(IQueryable<TSource>, IEnumerable<TSource>) polecenia , aby zwrócić elementy, które pojawiają się w każdej z dwóch sekwencji.
int[] id1 = { 44, 26, 92, 30, 71, 38 };
int[] id2 = { 39, 59, 83, 47, 26, 4, 30 };
// Get the numbers that occur in both arrays (id1 and id2).
IEnumerable<int> both = id1.AsQueryable().Intersect(id2);
foreach (int id in both)
Console.WriteLine(id);
/*
This code produces the following output:
26
30
*/
Dim id1() As Integer = {44, 26, 92, 30, 71, 38}
Dim id2() As Integer = {39, 59, 83, 47, 26, 4, 30}
' Get the numbers that occur in both arrays (id1 and id2).
Dim both As IEnumerable(Of Integer) = id1.AsQueryable().Intersect(id2)
Dim output As New System.Text.StringBuilder
For Each id As Integer In both
output.AppendLine(id)
Next
' Display the output.
MsgBox(output.ToString())
' This code produces the following output:
' 26
' 30
Uwagi
Metoda Intersect<TSource>(IQueryable<TSource>, IEnumerable<TSource>) generuje obiekt MethodCallExpression , który reprezentuje wywołanie Intersect<TSource>(IQueryable<TSource>, IEnumerable<TSource>) siebie jako skonstruowaną metodę ogólną. Następnie przekazuje MethodCallExpression wartość do CreateQuery<TElement>(Expression) metody IQueryProvider reprezentowanej przez Provider właściwość parametru source1
.
Zachowanie zapytania, które występuje w wyniku wykonania drzewa wyrażeń reprezentującego wywołanie Intersect<TSource>(IQueryable<TSource>, IEnumerable<TSource>) , zależy od implementacji typu parametru source1
. Oczekiwane zachowanie polega na tym, że zwracane są również wszystkie elementy w source1
obiekcie source2
.
Dotyczy
Intersect<TSource>(IQueryable<TSource>, IEnumerable<TSource>, IEqualityComparer<TSource>)
- Źródło:
- Queryable.cs
- Źródło:
- Queryable.cs
- Źródło:
- Queryable.cs
Tworzy część wspólną zestawu dwóch sekwencji, używając określonej IEqualityComparer<T> wartości do porównania wartości.
public:
generic <typename TSource>
[System::Runtime::CompilerServices::Extension]
static System::Linq::IQueryable<TSource> ^ Intersect(System::Linq::IQueryable<TSource> ^ source1, System::Collections::Generic::IEnumerable<TSource> ^ source2, System::Collections::Generic::IEqualityComparer<TSource> ^ comparer);
public static System.Linq.IQueryable<TSource> Intersect<TSource> (this System.Linq.IQueryable<TSource> source1, System.Collections.Generic.IEnumerable<TSource> source2, System.Collections.Generic.IEqualityComparer<TSource> comparer);
public static System.Linq.IQueryable<TSource> Intersect<TSource> (this System.Linq.IQueryable<TSource> source1, System.Collections.Generic.IEnumerable<TSource> source2, System.Collections.Generic.IEqualityComparer<TSource>? comparer);
static member Intersect : System.Linq.IQueryable<'Source> * seq<'Source> * System.Collections.Generic.IEqualityComparer<'Source> -> System.Linq.IQueryable<'Source>
<Extension()>
Public Function Intersect(Of TSource) (source1 As IQueryable(Of TSource), source2 As IEnumerable(Of TSource), comparer As IEqualityComparer(Of TSource)) As IQueryable(Of TSource)
Parametry typu
- TSource
Typ elementów sekwencji wejściowych.
Parametry
- source1
- IQueryable<TSource>
Zwracane IQueryable<T> są różne elementy, które również pojawiają się w source2
obiekcie.
- source2
- IEnumerable<TSource>
Zwracane IEnumerable<T> są również odrębne elementy, które pojawiają się również w pierwszej sekwencji.
- comparer
- IEqualityComparer<TSource>
Element IEqualityComparer<T> do porównywania wartości.
Zwraca
Element IQueryable<T> zawierający część wspólną zestawu dwóch sekwencji.
Wyjątki
source1
lub source2
ma wartość null
.
Uwagi
Metoda Intersect<TSource>(IQueryable<TSource>, IEnumerable<TSource>, IEqualityComparer<TSource>) generuje obiekt MethodCallExpression , który reprezentuje wywołanie Intersect<TSource>(IQueryable<TSource>, IEnumerable<TSource>, IEqualityComparer<TSource>) siebie jako skonstruowaną metodę ogólną. Następnie przekazuje MethodCallExpression wartość do CreateQuery<TElement>(Expression) metody IQueryProvider reprezentowanej przez Provider właściwość parametru source1
.
Zachowanie zapytania, które występuje w wyniku wykonania drzewa wyrażeń reprezentującego wywołanie Intersect<TSource>(IQueryable<TSource>, IEnumerable<TSource>, IEqualityComparer<TSource>) , zależy od implementacji typu parametru source1
. Oczekiwane zachowanie polega na tym, że zwracane są również wszystkie elementy w source1
obiekcie source2
. Parametr comparer
służy do porównywania elementów.