Queryable.LeftJoin Méthode
Définition
Important
Certaines informations portent sur la préversion du produit qui est susceptible d’être en grande partie modifiée avant sa publication. Microsoft exclut toute garantie, expresse ou implicite, concernant les informations fournies ici.
Surcharges
| Nom | Description |
|---|---|
| LeftJoin<TOuter,TInner,TKey,TResult>(IQueryable<TOuter>, IEnumerable<TInner>, Expression<Func<TOuter,TKey>>, Expression<Func<TInner,TKey>>, Expression<Func<TOuter,TInner,TResult>>, IEqualityComparer<TKey>) |
Met en corrélation les éléments de deux séquences en fonction des clés correspondantes. Une IEqualityComparer<T> spécifiée est utilisée pour comparer les clés. |
| LeftJoin<TOuter,TInner,TKey,TResult>(IQueryable<TOuter>, IEnumerable<TInner>, Expression<Func<TOuter,TKey>>, Expression<Func<TInner,TKey>>, Expression<Func<TOuter,TInner,TResult>>) |
Met en corrélation les éléments de deux séquences en fonction des clés correspondantes. Le comparateur d’égalité par défaut est utilisé pour comparer les clés. |
LeftJoin<TOuter,TInner,TKey,TResult>(IQueryable<TOuter>, IEnumerable<TInner>, Expression<Func<TOuter,TKey>>, Expression<Func<TInner,TKey>>, Expression<Func<TOuter,TInner,TResult>>, IEqualityComparer<TKey>)
- Source:
- Queryable.cs
- Source:
- Queryable.cs
Met en corrélation les éléments de deux séquences en fonction des clés correspondantes. Une IEqualityComparer<T> spécifiée est utilisée pour comparer les clés.
public:
generic <typename TOuter, typename TInner, typename TKey, typename TResult>
[System::Runtime::CompilerServices::Extension]
static System::Linq::IQueryable<TResult> ^ LeftJoin(System::Linq::IQueryable<TOuter> ^ outer, System::Collections::Generic::IEnumerable<TInner> ^ inner, System::Linq::Expressions::Expression<Func<TOuter, TKey> ^> ^ outerKeySelector, System::Linq::Expressions::Expression<Func<TInner, TKey> ^> ^ innerKeySelector, System::Linq::Expressions::Expression<Func<TOuter, TInner, TResult> ^> ^ resultSelector, System::Collections::Generic::IEqualityComparer<TKey> ^ comparer);
public static System.Linq.IQueryable<TResult> LeftJoin<TOuter,TInner,TKey,TResult>(this System.Linq.IQueryable<TOuter> outer, System.Collections.Generic.IEnumerable<TInner> inner, System.Linq.Expressions.Expression<Func<TOuter,TKey>> outerKeySelector, System.Linq.Expressions.Expression<Func<TInner,TKey>> innerKeySelector, System.Linq.Expressions.Expression<Func<TOuter,TInner?,TResult>> resultSelector, System.Collections.Generic.IEqualityComparer<TKey>? comparer);
static member LeftJoin : System.Linq.IQueryable<'Outer> * seq<'Inner> * System.Linq.Expressions.Expression<Func<'Outer, 'Key>> * System.Linq.Expressions.Expression<Func<'Inner, 'Key>> * System.Linq.Expressions.Expression<Func<'Outer, 'Inner, 'Result>> * System.Collections.Generic.IEqualityComparer<'Key> -> System.Linq.IQueryable<'Result>
<Extension()>
Public Function LeftJoin(Of TOuter, TInner, TKey, TResult) (outer As IQueryable(Of TOuter), inner As IEnumerable(Of TInner), outerKeySelector As Expression(Of Func(Of TOuter, TKey)), innerKeySelector As Expression(Of Func(Of TInner, TKey)), resultSelector As Expression(Of Func(Of TOuter, TInner, TResult)), comparer As IEqualityComparer(Of TKey)) As IQueryable(Of TResult)
Paramètres de type
- TOuter
Type des éléments de la première séquence.
- TInner
Type des éléments de la deuxième séquence.
- TKey
Type des clés retournées par les fonctions de sélecteur de clés.
- TResult
Type des éléments de résultat.
Paramètres
- outer
- IQueryable<TOuter>
Première séquence à joindre.
- inner
- IEnumerable<TInner>
Séquence à joindre à la première séquence.
- outerKeySelector
- Expression<Func<TOuter,TKey>>
Fonction permettant d’extraire la clé de jointure de chaque élément de la première séquence.
- innerKeySelector
- Expression<Func<TInner,TKey>>
Fonction permettant d’extraire la clé de jointure de chaque élément de la deuxième séquence.
- resultSelector
- Expression<Func<TOuter,TInner,TResult>>
Fonction permettant de créer un élément de résultat à partir de deux éléments correspondants.
- comparer
- IEqualityComparer<TKey>
IEqualityComparer<T> de hachage et de comparaison des clés.
Retours
Qui IEnumerable<T> a des éléments de type TResult obtenus en effectuant une jointure externe gauche sur deux séquences.
Exceptions
outerou inner ou outerKeySelectorinnerKeySelectorresultSelector ou est .null
Remarques
Cette méthode a au moins un paramètre de type Expression<TDelegate> dont l’argument de type est l’un des Func<T,TResult> types.
Pour ces paramètres, vous pouvez passer une expression lambda et elle sera compilée à un Expression<TDelegate>.
La méthode LeftJoin<TOuter,TInner,TKey,TResult>(IQueryable<TOuter>, IEnumerable<TInner>, Expression<Func<TOuter,TKey>>, Expression<Func<TInner,TKey>>, Expression<Func<TOuter,TInner,TResult>>, IEqualityComparer<TKey>) génère une MethodCallExpression qui représente l’appel de LeftJoin<TOuter,TInner,TKey,TResult>(IQueryable<TOuter>, IEnumerable<TInner>, Expression<Func<TOuter,TKey>>, Expression<Func<TInner,TKey>>, Expression<Func<TOuter,TInner,TResult>>, IEqualityComparer<TKey>) elle-même en tant que méthode générique construite.
Il transmet ensuite la MethodCallExpression à la méthode CreateQuery<TElement>(Expression) de l'IQueryProvider représentée par la propriété Provider du paramètre outer.
Le comportement de requête qui se produit suite à l’exécution d’une arborescence d’expressions qui représente l’appel de LeftJoin<TOuter,TInner,TKey,TResult>(IQueryable<TOuter>, IEnumerable<TInner>,
Expression<Func<TOuter,TKey>>, Expression<Func<TInner,TKey>>,
Expression<Func<TOuter,TInner,TResult>>, IEqualityComparer<TKey>) dépend de l’implémentation du type du paramètre outer.
Le comportement attendu est celui d’une jointure externe gauche.
Les fonctions outerKeySelector et innerKeySelector sont utilisées pour extraire les clés de outer et de inner, respectivement.
Ces clés sont comparées pour que l’égalité corresponde aux éléments de chaque séquence.
Une paire d’éléments est stockée pour chaque élément dans inner lequel correspond un élément outer, ainsi qu’une paire pour chaque élément qui outer n’a aucune correspondance dans inner.
Ensuite, la resultSelector fonction est appelée pour projeter un objet de résultat à partir de chaque paire d’éléments.
S’applique à
LeftJoin<TOuter,TInner,TKey,TResult>(IQueryable<TOuter>, IEnumerable<TInner>, Expression<Func<TOuter,TKey>>, Expression<Func<TInner,TKey>>, Expression<Func<TOuter,TInner,TResult>>)
- Source:
- Queryable.cs
- Source:
- Queryable.cs
Met en corrélation les éléments de deux séquences en fonction des clés correspondantes. Le comparateur d’égalité par défaut est utilisé pour comparer les clés.
public:
generic <typename TOuter, typename TInner, typename TKey, typename TResult>
[System::Runtime::CompilerServices::Extension]
static System::Linq::IQueryable<TResult> ^ LeftJoin(System::Linq::IQueryable<TOuter> ^ outer, System::Collections::Generic::IEnumerable<TInner> ^ inner, System::Linq::Expressions::Expression<Func<TOuter, TKey> ^> ^ outerKeySelector, System::Linq::Expressions::Expression<Func<TInner, TKey> ^> ^ innerKeySelector, System::Linq::Expressions::Expression<Func<TOuter, TInner, TResult> ^> ^ resultSelector);
public static System.Linq.IQueryable<TResult> LeftJoin<TOuter,TInner,TKey,TResult>(this System.Linq.IQueryable<TOuter> outer, System.Collections.Generic.IEnumerable<TInner> inner, System.Linq.Expressions.Expression<Func<TOuter,TKey>> outerKeySelector, System.Linq.Expressions.Expression<Func<TInner,TKey>> innerKeySelector, System.Linq.Expressions.Expression<Func<TOuter,TInner?,TResult>> resultSelector);
static member LeftJoin : System.Linq.IQueryable<'Outer> * seq<'Inner> * System.Linq.Expressions.Expression<Func<'Outer, 'Key>> * System.Linq.Expressions.Expression<Func<'Inner, 'Key>> * System.Linq.Expressions.Expression<Func<'Outer, 'Inner, 'Result>> -> System.Linq.IQueryable<'Result>
<Extension()>
Public Function LeftJoin(Of TOuter, TInner, TKey, TResult) (outer As IQueryable(Of TOuter), inner As IEnumerable(Of TInner), outerKeySelector As Expression(Of Func(Of TOuter, TKey)), innerKeySelector As Expression(Of Func(Of TInner, TKey)), resultSelector As Expression(Of Func(Of TOuter, TInner, TResult))) As IQueryable(Of TResult)
Paramètres de type
- TOuter
Type des éléments de la première séquence.
- TInner
Type des éléments de la deuxième séquence.
- TKey
Type des clés retournées par les fonctions de sélecteur de clés.
- TResult
Type des éléments de résultat.
Paramètres
- outer
- IQueryable<TOuter>
Première séquence à joindre.
- inner
- IEnumerable<TInner>
Séquence à joindre à la première séquence.
- outerKeySelector
- Expression<Func<TOuter,TKey>>
Fonction permettant d’extraire la clé de jointure de chaque élément de la première séquence.
- innerKeySelector
- Expression<Func<TInner,TKey>>
Fonction permettant d’extraire la clé de jointure de chaque élément de la deuxième séquence.
- resultSelector
- Expression<Func<TOuter,TInner,TResult>>
Fonction permettant de créer un élément de résultat à partir de deux éléments correspondants.
Retours
Qui IEnumerable<T> a des éléments de type TResult obtenus en effectuant une jointure externe gauche sur deux séquences.
Exceptions
outerou inner ou outerKeySelectorinnerKeySelectorresultSelector ou est .null
Remarques
Cette méthode a au moins un paramètre de type Expression<TDelegate> dont l’argument de type est l’un des Func<T,TResult> types.
Pour ces paramètres, vous pouvez passer une expression lambda et elle sera compilée à un Expression<TDelegate>.
La méthode LeftJoin<TOuter,TInner,TKey,TResult>(IQueryable<TOuter>, IEnumerable<TInner>, Expression<Func<TOuter,TKey>>, Expression<Func<TInner,TKey>>, Expression<Func<TOuter,TInner,TResult>>) génère une MethodCallExpression qui représente l’appel de LeftJoin<TOuter,TInner,TKey,TResult>(IQueryable<TOuter>, IEnumerable<TInner>, Expression<Func<TOuter,TKey>>, Expression<Func<TInner,TKey>>, Expression<Func<TOuter,TInner,TResult>>) elle-même en tant que méthode générique construite.
Il transmet ensuite la MethodCallExpression à la méthode CreateQuery<TElement>(Expression) de l'IQueryProvider représentée par la propriété Provider du paramètre outer.
Le comportement de requête qui se produit suite à l’exécution d’une arborescence d’expressions qui représente l’appel de LeftJoin<TOuter,TInner,TKey,TResult>(IQueryable<TOuter>, IEnumerable<TInner>,
Expression<Func<TOuter,TKey>>, Expression<Func<TInner,TKey>>,
Expression<Func<TOuter,TInner,TResult>>) dépend de l’implémentation du type du paramètre outer.
Le comportement attendu est celui d’une jointure externe gauche.
Les fonctions outerKeySelector et innerKeySelector sont utilisées pour extraire les clés de outer et de inner, respectivement.
Ces clés sont comparées pour que l’égalité corresponde aux éléments de chaque séquence.
Une paire d’éléments est stockée pour chaque élément dans inner lequel correspond un élément outer, ainsi qu’une paire pour chaque élément qui outer n’a aucune correspondance dans inner.
Ensuite, la resultSelector fonction est appelée pour projeter un objet de résultat à partir de chaque paire d’éléments.