Maison > base de données > tutoriel mysql > Comment OUTER et CROSS APPLY peuvent-ils améliorer la flexibilité et les performances des requêtes SQL ?

Comment OUTER et CROSS APPLY peuvent-ils améliorer la flexibilité et les performances des requêtes SQL ?

DDD
Libérer: 2025-01-10 07:13:41
original
377 Les gens l'ont consulté

How Can OUTER and CROSS APPLY Enhance SQL Query Flexibility and Performance?

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>
Copier après la connexion

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>
Copier après la connexion

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>
Copier après la connexion

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>
Copier après la connexion

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!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal