Queryable.Union Метод
Определение
Важно!
Некоторые сведения относятся к предварительной версии продукта, в которую до выпуска могут быть внесены существенные изменения. Майкрософт не предоставляет никаких гарантий, явных или подразумеваемых, относительно приведенных здесь сведений.
Находит объединение множеств, представленных двумя последовательностями.
Перегрузки
Union<TSource>(IQueryable<TSource>, IEnumerable<TSource>) |
Находит объединение множеств, представленных двумя последовательностями, используя для сравнения значений компаратор проверки на равенство по умолчанию. |
Union<TSource>(IQueryable<TSource>, IEnumerable<TSource>, IEqualityComparer<TSource>) |
Находит объединение множеств, представленных двумя последовательностями, используя указанный компаратор IEqualityComparer<T>. |
Union<TSource>(IQueryable<TSource>, IEnumerable<TSource>)
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
Находит объединение множеств, представленных двумя последовательностями, используя для сравнения значений компаратор проверки на равенство по умолчанию.
public:
generic <typename TSource>
[System::Runtime::CompilerServices::Extension]
static System::Linq::IQueryable<TSource> ^ Union(System::Linq::IQueryable<TSource> ^ source1, System::Collections::Generic::IEnumerable<TSource> ^ source2);
public static System.Linq.IQueryable<TSource> Union<TSource> (this System.Linq.IQueryable<TSource> source1, System.Collections.Generic.IEnumerable<TSource> source2);
static member Union : System.Linq.IQueryable<'Source> * seq<'Source> -> System.Linq.IQueryable<'Source>
<Extension()>
Public Function Union(Of TSource) (source1 As IQueryable(Of TSource), source2 As IEnumerable(Of TSource)) As IQueryable(Of TSource)
Параметры типа
- TSource
Тип элементов входных последовательностей.
Параметры
- source1
- IQueryable<TSource>
Последовательность, различающиеся элементы которой образуют первое множество для операции объединения.
- source2
- IEnumerable<TSource>
Последовательность, различающиеся элементы которой образуют второе множество для операции объединения.
Возвращаемое значение
Объект IQueryable<T>, который содержит элементы, имеющиеся в обеих входных последовательностях, кроме дубликатов.
Исключения
Параметр source1
или source2
имеет значение null
.
Примеры
В следующем примере кода показано, как использовать Union<TSource>(IQueryable<TSource>, IEnumerable<TSource>) для получения объединения наборов двух последовательностей.
int[] ints1 = { 5, 3, 9, 7, 5, 9, 3, 7 };
int[] ints2 = { 8, 3, 6, 4, 4, 9, 1, 0 };
// Get the set union of the items in the two arrays.
IEnumerable<int> union = ints1.AsQueryable().Union(ints2);
foreach (int num in union)
Console.Write("{0} ", num);
/*
This code produces the following output:
5 3 9 7 8 6 4 1 0
*/
Dim ints1() As Integer = {5, 3, 9, 7, 5, 9, 3, 7}
Dim ints2() As Integer = {8, 3, 6, 4, 4, 9, 1, 0}
' Get the set union of the items in the two arrays.
Dim union = ints1.AsQueryable().Union(ints2)
Dim output As New System.Text.StringBuilder
For Each num As Integer In union
output.Append(String.Format("{0} ", num))
Next
' Display the output.
MsgBox(output.ToString())
' This code produces the following output:
' 5 3 9 7 8 6 4 1 0
Комментарии
Метод Union<TSource>(IQueryable<TSource>, IEnumerable<TSource>) создает объект , MethodCallExpression представляющий вызов Union<TSource>(IQueryable<TSource>, IEnumerable<TSource>) как сконструированный универсальный метод. Затем он передает в MethodCallExpressionCreateQuery<TElement>(Expression) метод объекта , IQueryProvider представленный свойством Providersource1
параметра .
Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Union<TSource>(IQueryable<TSource>, IEnumerable<TSource>) , зависит от реализации типа source1
параметра. Ожидаемое поведение заключается в том, что возвращается объединение наборов элементов в source1
и source2
.
Применяется к
Union<TSource>(IQueryable<TSource>, IEnumerable<TSource>, IEqualityComparer<TSource>)
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
Находит объединение множеств, представленных двумя последовательностями, используя указанный компаратор IEqualityComparer<T>.
public:
generic <typename TSource>
[System::Runtime::CompilerServices::Extension]
static System::Linq::IQueryable<TSource> ^ Union(System::Linq::IQueryable<TSource> ^ source1, System::Collections::Generic::IEnumerable<TSource> ^ source2, System::Collections::Generic::IEqualityComparer<TSource> ^ comparer);
public static System.Linq.IQueryable<TSource> Union<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> Union<TSource> (this System.Linq.IQueryable<TSource> source1, System.Collections.Generic.IEnumerable<TSource> source2, System.Collections.Generic.IEqualityComparer<TSource>? comparer);
static member Union : System.Linq.IQueryable<'Source> * seq<'Source> * System.Collections.Generic.IEqualityComparer<'Source> -> System.Linq.IQueryable<'Source>
<Extension()>
Public Function Union(Of TSource) (source1 As IQueryable(Of TSource), source2 As IEnumerable(Of TSource), comparer As IEqualityComparer(Of TSource)) As IQueryable(Of TSource)
Параметры типа
- TSource
Тип элементов входных последовательностей.
Параметры
- source1
- IQueryable<TSource>
Последовательность, различающиеся элементы которой образуют первое множество для операции объединения.
- source2
- IEnumerable<TSource>
Последовательность, различающиеся элементы которой образуют второе множество для операции объединения.
- comparer
- IEqualityComparer<TSource>
Компаратор IEqualityComparer<T>, используемый для сравнения значений.
Возвращаемое значение
Объект IQueryable<T>, который содержит элементы, имеющиеся в обеих входных последовательностях, кроме дубликатов.
Исключения
Параметр source1
или source2
имеет значение null
.
Комментарии
Метод Union<TSource>(IQueryable<TSource>, IEnumerable<TSource>, IEqualityComparer<TSource>) создает объект , MethodCallExpression представляющий вызов Union<TSource>(IQueryable<TSource>, IEnumerable<TSource>, IEqualityComparer<TSource>) как сконструированный универсальный метод. Затем он передает в MethodCallExpressionCreateQuery<TElement>(Expression) метод объекта , IQueryProvider представленный свойством Providersource1
параметра .
Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Union<TSource>(IQueryable<TSource>, IEnumerable<TSource>, IEqualityComparer<TSource>) , зависит от реализации типа source1
параметра. Ожидаемое поведение заключается в том, что возвращается объединение наборов элементов в source1
и source2
. Параметр comparer
используется для сравнения значений.