Maison >base de données >tutoriel mysql >Qu'est-ce que le CTE dans SQL

Qu'est-ce que le CTE dans SQL

青灯夜游
青灯夜游original
2019-01-21 13:18:4714324parcourir

CTE signifie Common Table Expression, qui est un jeu de résultats nommé temporaire et renvoie toujours un jeu de résultats. Il a été introduit par le standard SQL pour simplifier les requêtes SQL. L'article suivant vous présentera CTE (expression de table commune). J'espère qu'il vous sera utile.

Qu'est-ce que le CTE dans SQL

Qu'est-ce que le CTE ?

Une expression de table commune (CTE) peut être considérée comme un jeu de résultats temporaire défini dans la portée d'exécution d'une seule instruction SELECT, INSERT, UPDATE, DELETE ou CREATE VIEW. Un CTE est similaire à une table dérivée dans la mesure où il n'est pas stocké en tant qu'objet et persiste uniquement lors des requêtes. Contrairement aux tables dérivées, les CTE peuvent être auto-référentielles et référencées plusieurs fois dans la même requête. [Tutoriels vidéo associés recommandés : Tutoriel MySQL]

La structure de CTE

CTE est représentée par le nom de l'expression de CTE , composé d'un mot-clé AS et d'une instruction SELECT. Une fois qu'un CTE est défini, il peut être référencé comme une table ou une vue dans une instruction SELECT, INSERT, UPDATE ou DELETE. Un CTE peut également être utilisé dans une instruction CREATE VIEW dans le cadre de son instruction SELECT de définition.

La structure syntaxique de base de CTE est :

WITH Expression_Name [ ( ColumnName [1,...n] ) ]
AS
( CTE query definition )

Explication : Nous pouvons définir CTE en ajoutant la clause WITH directement avant l'instruction SELECT, INSERT, UPDATE, DELETE ou MERGE. La clause WITH peut contenir un ou plusieurs CTE séparés par des virgules.

La déclaration pour gérer un CTE est :

SELECT <column_list>
FROM expression_name;

Types de CTE

Il existe deux types de CTE : Récursifs et non récursifs.

CTE récursif : C'est une expression de table courante qui fait référence à elle-même.

Les CTE non récursifs, comme leur nom l'indique, n'utilisent pas de récursivité ; ils ne font pas référence à eux-mêmes.

Avantages de l'utilisation du CTE

Lisibilité : CTE améliore la lisibilité. Plutôt que de regrouper toute la logique de requête dans une seule grande requête, créez plusieurs CTE qui seront combinés ultérieurement dans l'instruction. Cela vous permet d'obtenir les morceaux de données requis et de les combiner dans le SELECT final.

Vue alternative : Vous pouvez remplacer la vue par CTE. Ceci est pratique si vous n'êtes pas autorisé à créer un objet de vue ou si vous ne souhaitez pas en créer un car il ne sera utilisé que dans cette seule requête.

Récursif : L'utilisation de CTE créera une requête récursive, c'est-à-dire que vous pourrez appeler votre propre requête. Ceci est pratique lorsque vous devez travailler avec des données hiérarchiques telles que des organigrammes.

Limitations : Surmontez les limitations de l'instruction SELECT, telles que le référencement lui-même (récursivité) ou l'utilisation de fonctions non déterministes pour exécuter GROUP BY.

Classement : Chaque fois que vous souhaitez utiliser des fonctions de classement telles que ROW_NUMBER(), RANK(), NTILE(), etc.

Ce qui précède représente l’intégralité du contenu de cet article, j’espère qu’il sera utile à l’étude de chacun. Pour un contenu plus passionnant, vous pouvez prêter attention aux colonnes de didacticiels pertinentes du site Web PHP chinois ! ! !

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!

Déclaration:
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