Littéraux (Entity SQL)
Cette rubrique décrit la prise en charge des littéraux dans Entité SQL.
Null
Le littéral Null est utilisé pour représenter la valeur Null d'un type quel qu'il soit. Un littéral Null est compatible avec n'importe quel type.
Des valeurs Null typées peuvent être créées par cast sur un littéral Null. Pour plus d'informations, voir CAST (Entity SQL).
Pour connaître les règles d'utilisation de littéraux Null flottants, voir Littéraux Null et inférence de type (Entity SQL).
Boolean
Les littéraux booléens sont représentés par les mots clés true et false.
Integer
Les littéraux entiers (integer) peuvent être de type Int32 ou Int64. Un littéral Int32 est une série de caractères numériques. Un littéral Int64 est une série de caractères numériques suivie d'un L majuscule.
Decimal
Un nombre à virgule fixe (decimal) est une série de caractères numériques entrecoupée d'une virgule (,) et suivie d'un M majuscule.
Float, Double
Un nombre à virgule flottante double précision est une série de caractères numériques entrecoupée d'une virgule (,) et suivie d'un exposant. Un nombre à virgule flottante simple précision (ou float) est une syntaxe de nombre à virgule flottante double précision suivie d'un f minuscule.
String
Une chaîne (string) est une série de caractères figurant entre guillemets. Les guillemets peuvent être soit simples ('
) tous les deux, soit doubles (") tous les deux. Les littéraux de chaîne de caractères peuvent être au format Unicode ou non. Pour déclarer un littéral de chaîne de caractères comme étant au format Unicode, faites-le précéder d'un N majuscule. Par défaut, les littéraux de chaîne de caractères ne sont pas au format Unicode. Aucun espace ne doit figurer entre le N et la charge utile du littéral de chaîne, et le N doit être majuscule.
'hello' -- non-Unicode character string literal
N'hello' -- Unicode character string literal
"x"
N"This is a string!"
'so is THIS'
DateTime
Un littéral de date/heure (datetime) est indépendant des paramètres régionaux. Il est composé d'une partie date et d'une partie heure. Ces deux parties sont obligatoires et il n'existe pas de valeur par défaut.
La partie date doit avoir le format : YYYY-MM-DD, où YYYY est une année à quatre chiffres comprise entre 0001 et 9999, MM est une valeur comprise entre 1 et 12 qui représente le mois et DD est la valeur du jour qui est valide pour le mois MM donné.
La partie heure doit avoir le format : HH:MM[:SS[.fffffff]], où HH est la valeur d'heure comprise entre 0 et 23 inclus, MM est la valeur de minute comprise entre 0 et 59 inclus, SS est la valeur de seconde comprise entre 0 et 59 inclus, et fffffff est la valeur de fraction de seconde comprise entre 0 et 9999999. Toutes les plages de valeurs sont inclusives. Les fractions de secondes sont facultatives. Les secondes sont facultatives à moins que les fractions de secondes soient spécifiées ; auquel cas, les secondes sont requises. Lorsque les secondes ou les fractions de secondes ne sont pas spécifiées, la valeur par défaut zéro est utilisée.
Le symbole DATETIME et la charge utile du littéral peuvent être séparés d'autant d'espaces que nécessaire, mais pas de nouvelles lignes.
DATETIME'2006-10-1 23:11'
DATETIME'2006-12-25 01:01:00.0000000' -- same as DATETIME'2006-12-25 01:01'
Time
Un littéral d'heure (time) est indépendant des paramètres régionaux. Il n'est composé que d'une partie heure. La partie heure est obligatoire et n'est assortie d'aucune valeur par défaut. Elle doit respecter le format HH:MM[:SS[.fffffff]], où HH est la valeur d'heure comprise entre 0 et 23 inclus, MM est la valeur de minute comprise entre 0 et 59 inclus, SS est la valeur de seconde comprise entre 0 et 59 inclus, et fffffff est la valeur de fraction de seconde comprise entre 0 et 9999999 inclus. Toutes les plages de valeurs sont inclusives. Les fractions de secondes sont facultatives. Les secondes sont facultatives à moins que les fractions de secondes soient spécifiées ; auquel cas, les secondes sont requises. Lorsque les secondes ou les fractions de secondes ne sont pas spécifiées, la valeur par défaut zéro est utilisée.
Le symbole TIME et la charge utile du littéral peuvent être séparés d'autant d'espaces que nécessaire, mais pas de nouvelles lignes.
TIME‘23:11’
TIME‘01:01:00.1234567’
DateTimeOffset
Un littéral datetimeoffset est indépendant des paramètres régionaux. Il est composé d'une partie date, d'une partie heure et d'une partie décalage. Toutes ces parties sont obligatoires et il n'existe pas de valeur par défaut. La partie date doit respecter le format YYYY-MM-DD, où YYYY est une année à quatre chiffres comprise entre 0001 et 9999, MM est une valeur comprise entre 1 et 12 qui représente le mois et DD est la valeur du jour valide pour le mois donné. La partie heure doit respecter le format HH:MM[:SS[.fffffff]], où HH est la valeur d'heure comprise entre 0 et 23 inclus, MM est la valeur de minute comprise entre 0 et 59 inclus, SS est la valeur de seconde comprise entre 0 et 59 inclus, et fffffff est la valeur de fraction de seconde comprise entre 0 et 9999999 inclus. Toutes les plages de valeurs sont inclusives. Les fractions de secondes sont facultatives. Les secondes sont facultatives à moins que les fractions de secondes soient spécifiées ; auquel cas, les secondes sont requises. Lorsque les secondes ou les fractions de secondes ne sont pas spécifiées, la valeur par défaut zéro est utilisée. La partie décalage doit respecter le format {+ | -} HH:MM, où HH et MM ont la même signification que dans la partie heure. Toutefois, la plage du décalage doit être comprise entre -14:00 et +14:00.
Le symbole DATETIMEOFFSET et la charge utile du littéral peuvent être séparés d'autant d'espaces que nécessaire, mais pas de nouvelles lignes.
DATETIMEOFFSET‘2006-10-1 23:11 +02:00’
DATETIMEOFFSET‘2006-12-25 01:01:00.0000000 -08:30’
Remarque |
---|
Une valeur littérale Entity SQL valide peut se situer hors des plages prises en charge pour CLR ou la source de données. Cela peut donner lieu à une exception. |
Binary
Un littéral de chaîne binaire (binary) est une séquence de chiffres hexadécimaux délimitée par des guillemets simples à la suite du mot clé binary ou du symbole de raccourci X. Notez que le mot clé binary ne respecte pas la casse. Notez également que les espaces sont autorisés entre le mot clé binary et la valeur de chaîne binaire.
Le symbole de raccourci X doit être en majuscule et aucun espace ne doit figurer entre le symbole X et la chaîne binaire. Les caractères hexadécimaux ne respectent pas la casse. Si le littéral est composé d'un nombre impair de chiffres hexadécimaux, un chiffre zéro hexadécimal lui sera ajouté en préfixe pour permettre son alignement sur le prochain chiffre hexadécimal pair. Il n'existe pas de limite formelle relativement à la taille de la chaîne binaire.
Aucun espace ne doit figurer entre le symbole X et la charge utile du littéral de chaîne, et X doit être en majuscule. Le symbole BINARY et la charge utile du littéral peuvent être séparés d'autant d'espaces que nécessaire, mais pas de nouvelles lignes.
Binary'00ffaabb'
X'ABCabc'
BINARY '0f0f0f0F0F0F0F0F0F0F'
X'' –- empty binary string
Guid
Un littéral GUID représente un identificateur global unique. Il est composé du mot clé GUID, suivi de chiffres hexadécimaux présentés au format dit de Registre : 8-4-4-4-12 entre guillemets simples. Les chiffres hexadécimaux ne respectent pas la casse.
Le symbole GUID et la charge utile du littéral peuvent être séparés d'autant d'espaces que nécessaire, mais pas de nouvelles lignes.
Guid'1afc7f5c-ffa0-4741-81cf-f12eAAb822bf'
GUID '1AFC7F5C-FFA0-4741-81CF-F12EAAB822BF'