Application pratique de OUTER et CROSS APPLY en SQL
OUTER et CROSS APPLY sont deux structures très précieuses en SQL qui peuvent améliorer la flexibilité et les performances des requêtes. Même si les exemples classiques peuvent sembler ésotériques, ces structures ont des applications pratiques dans une variété de scénarios.
1.Obtenir efficacement des données pertinentes
Supposons que vous ayez deux tables : la table Contacts contient les coordonnées et la table CommunicationEntries contient les canaux de communication (téléphone, fax, e-mail). Pour récupérer les informations de contact et les détails de communication associés, vous pouvez utiliser CROSS APPLY comme suit :
<code class="language-sql">SELECT c.name, ce.communicationType, ce.channel FROM Contacts c CROSS APPLY ( SELECT * FROM CommunicationEntries ce WHERE ce.contactId = c.contactId ) ce;</code>
2. Utiliser les fonctions table
Les fonctions table (TVF) fournissent un moyen de générer dynamiquement des données tabulaires. CROSS APPLY vous permet d'appeler le TVF pour chaque ligne de la requête externe. Par exemple, pour afficher le plan de requête pour une requête en cours d'exécution :
<code class="language-sql">SELECT * FROM sys.dm_exec_query_stats AS qs CROSS APPLY sys.dm_exec_query_plan(qs.plan_handle);</code>
3. Réutiliser les alias de colonnes
Parfois, vous devez réutiliser les alias de colonnes dans une requête complexe. CROSS APPLY vous permet de définir plusieurs alias pour la même colonne, rendant les requêtes plus faciles à lire et à gérer. Par exemple :
<code class="language-sql">SELECT number, doubled_number, doubled_number_plus_one FROM master..spt_values CROSS APPLY (SELECT 2 * CAST(number AS BIGINT)) CA1(doubled_number) CROSS APPLY (SELECT doubled_number + 1) CA2(doubled_number_plus_one);</code>
4. Déroulez efficacement les données
Dans une structure de table normalisée, les données sont stockées dans des colonnes. Le déroulement aplatit ces données, créant des lignes pour chaque attribut. OUTER APPLY peut effectuer un déroulement efficace, en particulier lorsque plusieurs ensembles de colonnes doivent être déroulés. Considérez le scénario suivant :
<code class="language-sql">SELECT Id, Foo, Bar, GrpName FROM T CROSS APPLY (VALUES('1', Foo1, Bar1), ('2', Foo2, Bar2), ('3', Foo3, Bar3)) V(GrpName, Foo, Bar);</code>
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!