Queryable.Except メソッド
定義
重要
一部の情報は、リリース前に大きく変更される可能性があるプレリリースされた製品に関するものです。 Microsoft は、ここに記載されている情報について、明示または黙示を問わず、一切保証しません。
2 つのシーケンスのセット差を生成します。
オーバーロード
Except<TSource>(IQueryable<TSource>, IEnumerable<TSource>) |
既定の等値比較子を使用して値を比較することにより、2 つのシーケンスのセット差を生成します。 |
Except<TSource>(IQueryable<TSource>, IEnumerable<TSource>, IEqualityComparer<TSource>) |
指定した IEqualityComparer<T> を使用して値を比較することにより、2 つのシーケンスのセット差を生成します。 |
Except<TSource>(IQueryable<TSource>, IEnumerable<TSource>)
- ソース:
- Queryable.cs
- ソース:
- Queryable.cs
- ソース:
- Queryable.cs
既定の等値比較子を使用して値を比較することにより、2 つのシーケンスのセット差を生成します。
public:
generic <typename TSource>
[System::Runtime::CompilerServices::Extension]
static System::Linq::IQueryable<TSource> ^ Except(System::Linq::IQueryable<TSource> ^ source1, System::Collections::Generic::IEnumerable<TSource> ^ source2);
public static System.Linq.IQueryable<TSource> Except<TSource> (this System.Linq.IQueryable<TSource> source1, System.Collections.Generic.IEnumerable<TSource> source2);
static member Except : System.Linq.IQueryable<'Source> * seq<'Source> -> System.Linq.IQueryable<'Source>
<Extension()>
Public Function Except(Of TSource) (source1 As IQueryable(Of TSource), source2 As IEnumerable(Of TSource)) As IQueryable(Of TSource)
型パラメーター
- TSource
入力シーケンスの要素の型。
パラメーター
- source1
- IQueryable<TSource>
source2
に含まれていない要素が返される IQueryable<T>。
- source2
- IEnumerable<TSource>
最初のシーケンスでも発生する要素が、返されるシーケンスに表示されない IEnumerable<T>。
戻り値
2 つのシーケンスのセット差を含む IQueryable<T>。
例外
source1
または source2
が null
。
例
次のコード例では、Except<TSource>(IQueryable<TSource>, IEnumerable<TSource>) を使用して、最初のソース シーケンスにのみ表示される要素を返す方法を示します。
double[] numbers1 = { 2.0, 2.1, 2.2, 2.3, 2.4, 2.5 };
double[] numbers2 = { 2.2 };
// Get the numbers from the first array that
// are NOT in the second array.
IEnumerable<double> onlyInFirstSet =
numbers1.AsQueryable().Except(numbers2);
foreach (double number in onlyInFirstSet)
Console.WriteLine(number);
/*
This code produces the following output:
2
2.1
2.3
2.4
2.5
*/
Dim numbers1() As Double = {2.0, 2.1, 2.2, 2.3, 2.4, 2.5}
Dim numbers2() As Double = {2.2}
' Get the numbers from the first array that
' are NOT in the second array.
Dim onlyInFirstSet As IEnumerable(Of Double) = _
numbers1.AsQueryable().Except(numbers2)
Dim output As New System.Text.StringBuilder
For Each number As Double In onlyInFirstSet
output.AppendLine(number)
Next
' Display the output.
MsgBox(output.ToString())
' This code produces the following output:
'
' 2
' 2.1
' 2.3
' 2.4
' 2.5
注釈
Except<TSource>(IQueryable<TSource>, IEnumerable<TSource>) メソッドは、構築されたジェネリック メソッドとしての呼び出し自体 Except<TSource>(IQueryable<TSource>, IEnumerable<TSource>) 表す MethodCallExpression を生成します。 次に、source1
パラメーターの Provider プロパティで表される IQueryProvider の CreateQuery<TElement>(Expression) メソッドに MethodCallExpression を渡します。
呼び出し Except<TSource>(IQueryable<TSource>, IEnumerable<TSource>) を表す式ツリーを実行した結果として発生するクエリ動作は、source1
パラメーターの型の実装によって異なります。 予期される動作は、source1
内のすべての要素が、source2
内にある要素を除いて返されるということです。
適用対象
Except<TSource>(IQueryable<TSource>, IEnumerable<TSource>, IEqualityComparer<TSource>)
- ソース:
- Queryable.cs
- ソース:
- Queryable.cs
- ソース:
- Queryable.cs
指定した IEqualityComparer<T> を使用して値を比較することにより、2 つのシーケンスのセット差を生成します。
public:
generic <typename TSource>
[System::Runtime::CompilerServices::Extension]
static System::Linq::IQueryable<TSource> ^ Except(System::Linq::IQueryable<TSource> ^ source1, System::Collections::Generic::IEnumerable<TSource> ^ source2, System::Collections::Generic::IEqualityComparer<TSource> ^ comparer);
public static System.Linq.IQueryable<TSource> Except<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> Except<TSource> (this System.Linq.IQueryable<TSource> source1, System.Collections.Generic.IEnumerable<TSource> source2, System.Collections.Generic.IEqualityComparer<TSource>? comparer);
static member Except : System.Linq.IQueryable<'Source> * seq<'Source> * System.Collections.Generic.IEqualityComparer<'Source> -> System.Linq.IQueryable<'Source>
<Extension()>
Public Function Except(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
に含まれていない要素が返される IQueryable<T>。
- source2
- IEnumerable<TSource>
最初のシーケンスでも発生する要素が、返されるシーケンスに表示されない IEnumerable<T>。
- comparer
- IEqualityComparer<TSource>
値を比較する IEqualityComparer<T>。
戻り値
2 つのシーケンスのセット差を含む IQueryable<T>。
例外
source1
または source2
が null
。
注釈
Except<TSource>(IQueryable<TSource>, IEnumerable<TSource>, IEqualityComparer<TSource>) メソッドは、構築されたジェネリック メソッドとしての呼び出し自体 Except<TSource>(IQueryable<TSource>, IEnumerable<TSource>, IEqualityComparer<TSource>) 表す MethodCallExpression を生成します。 次に、source1
パラメーターの Provider プロパティで表される IQueryProvider の CreateQuery<TElement>(Expression) メソッドに MethodCallExpression を渡します。
呼び出し Except<TSource>(IQueryable<TSource>, IEnumerable<TSource>, IEqualityComparer<TSource>) を表す式ツリーを実行した結果として発生するクエリ動作は、source1
パラメーターの型の実装によって異なります。 予期される動作は、source1
内のすべての要素が返され、source2
内にある要素を除き、comparer
を使用して値を比較することです。
適用対象
.NET