SELECT (Entity SQL)
Indique les éléments retournés par une requête.
SELECT [ ALL | DISTINCT ] [ topSubclause ] aliasedExpr
[{ , aliasedExpr }]
or
SELECT VALUE [ ALL | DISTINCT ] [ topSubclause ] expr
Arguments
- ALL
Indique que les doublons peuvent apparaître dans l'ensemble de résultats. ALL est la valeur par défaut.
- DISTINCT
Indique que seuls les résultats uniques peuvent apparaître dans l'ensemble de résultats.
- VALUE
Autorise la spécification d'un seul élément et n'ajoute pas de wrapper de ligne.
topSubclause
Toute expression valide indiquant le nombre de premiers résultats à retourner de la requête, sous la forme top (expr).Le paramètre LIMIT de l'opérateur ORDER BY (Entity SQL) permet également de sélectionner les n premiers éléments dans le jeu de résultats.
aliasedExpr
Expression sous la forme :expr comme identifier | expr
- expr
Littéral ou expression.
Notes
La clause SELECT est évaluée après les clauses FROM (Entity SQL), GROUP BY (Entity SQL) et HAVING (Entity SQL). La clause SELECT ne peut faire référence qu'aux éléments qui se trouvent actuellement dans l'étendue (de la clause FROM ou d'étendues externes). Si une clause GROUP BY a été spécifiée, la clause SELECT ne peut faire référence qu'aux alias des clés GROUP BY. Le référencement des éléments de la clause FROM n'est autorisé que dans les fonctions d'agrégation.
La liste constituée d'une ou plusieurs expressions de requête figurant après le mot clé SELECT est appelée « liste de sélection » ou, de manière plus formelle, « projection ». La forme de projection la plus courante est une expression de requête unique. Si vous sélectionnez un membremember1
dans une collection collection1
, vous générez une nouvelle collection constituée de toutes les valeursmember1
pour chaque objet de collection1
, comme l'illustre l'exemple suivant.
SELECT collection1.member1 FROM collection1
Par exemple, sicustomers
est une collection de type Customer possédant une propriétéName
de type string, le fait de sélectionnerName
danscustomers
génèrera une collection de chaînes, comme l'illustre l'exemple suivant.
SELECT customers.Name FROM customers AS c
Il est également possible d'utiliser la syntaxe JOIN (FULL, INNER, LEFT, OUTER, ON et RIGHT). ON est requis pour les jointures internes et n'est pas autorisé pour les jointures croisées.
Clauses « row select » et « value select »
Entité SQL prend en charge deux variantes de la clause SELECT. La première variante, « row select », est identifiée par le mot clé SELECT et peut être utilisée pour spécifier une ou plusieurs valeurs devant être projetées. Étant donné qu'un wrapper de ligne est implicitement ajouté de part et d'autre des valeurs retournées, le résultat de l'expression de requête est toujours un multiensemble de lignes.
Chaque expression de requête figurant dans une clause « row select » doit spécifier un alias. Si aucun alias n'est spécifié, Entité SQL essaie d'en générer un en utilisant les règles de génération d'alias.
L'autre variante de la clause SELECT, « value select », est identifiée par le mot clé SELECT VALUE. Elle autorise la spécification d'une seule valeur et n'ajoute pas de wrapper de ligne.
Une clause « row select » peut toujours être exprimée en termes de sélection de valeur (SELECT VALUE), comme l'illustre l'exemple suivant.
SELECT 1 AS a, "abc" AS b, a+34 AS c
SELECT VALUE ROW(1 AS a, "abc" AS b, a+34 AS c)
Modificateurs All et Distinct
Les deux variantes de la clause SELECT d'Entité SQL permettent de spécifier un modificateur ALL ou DISTINCT. Si le modificateur DISTINCT est spécifié, les doublons sont éliminés de la collection créée par l'expression de requête (jusqu'à la clause SELECT elle-même incluse). Si le modificateur ALL est spécifié, aucune élimination de doublons n'est réalisée ; ALL est spécifié par défaut.
Différences par rapport à Transact-SQL
Contrairement à Transact-SQL, Entité SQL ne prend pas en charge l'utilisation de l'argument * dans la clause SELECT. En revanche, Entité SQL autorise les requêtes pour projeter des enregistrements entiers en faisant référence aux alias de collection de la clause FROM, comme l'illustre l'exemple suivant.
SELECT * FROM T1, T2
L'expression de requête Transact-SQL précédente est exprimée dans Entité SQL de la façon suivante :
SELECT a1, a2 FROM T1 AS a1, T2 AS a2
Exemple
La requête Entity SQL ci-dessous utilise l'opérateur SELECT pour spécifier les éléments qu'une requête doit retourner. Cette requête est basée sur le modèle de vente AdventureWorks Sales Model. Pour compiler et exécuter cette requête, procédez comme suit :
Suivez la procédure indiquée dans Procédure : exécuter une requête qui retourne des résultats StructuralType (EntityClient).
Passez à la méthode
ExecuteStructuralTypeQuery
la requête suivante en tant qu'argument :
SELECT VALUE product FROM AdventureWorksEntities.Product AS product
La sortie est présentée ci-dessous :
ProductID: 1
Name: Adjustable Race
ProductNumber: AR-5381
MakeFlag: False
ProductID: 2
Name: Bearing Ball
ProductNumber: BA-8327
MakeFlag: False
ProductID: 3
Name: BB Ball Bearing
ProductNumber: BE-2349
MakeFlag: True
ProductID: 4
Name: Headset Ball Bearings
ProductNumber: BE-2908
MakeFlag: False
ProductID: 316
Name: Blade
ProductNumber: BL-2036
MakeFlag: True
...