Réponses:
CONVERT
est spécifique à SQL Server, CAST
est ANSI.
CONVERT
est plus flexible dans la mesure où vous pouvez formater des dates, etc. À part cela, elles sont à peu près les mêmes. Si vous ne vous souciez pas des fonctionnalités étendues, utilisez CAST
.
ÉDITER:
Comme indiqué par @beruic et @CF dans les commentaires ci-dessous, il y a une perte de précision possible lorsqu'une conversion implicite est utilisée (c'est-à-dire que vous n'utilisez ni CAST ni CONVERT). Pour plus d'informations, consultez CAST et CONVERT et en particulier ce graphique: Tableau de conversion des types de données SQL Server . Avec ces informations supplémentaires, les conseils originaux restent les mêmes. Utilisez CAST si possible.
Convert a un paramètre de style pour les conversions de date en chaîne.
CAST est du SQL standard, mais CONVERT ne concerne que le dialecte T-SQL. Nous avons un petit avantage pour convertir dans le cas de datetime.
Avec CAST, vous indiquez l'expression et le type cible; avec CONVERT, il y a un troisième argument représentant le style de la conversion, qui est pris en charge pour certaines conversions, comme entre les chaînes de caractères et les valeurs de date et d'heure. Par exemple, CONVERT (DATE, '1/2/2012', 101) convertit la chaîne de caractères littérale en DATE en utilisant le style 101 représentant la norme des États-Unis.
Pour développer la réponse ci-dessus copiée par Shakti , j'ai en fait pu mesurer une différence de performance entre les deux fonctions.
Je testais les performances des variantes de la solution pour cette question et constaté que l'écart type et les durées d'exécution maximales étaient plus importants lors de l'utilisation CAST
.
* Temps en millisecondes, arrondis au 1 / 300e de seconde près selon la précision du DateTime
type
Quelque chose que personne ne semble avoir encore noté est la lisibilité. Ayant…
CONVERT(SomeType,
SomeReallyLongExpression
+ ThatMayEvenSpan
+ MultipleLines
)
… Peut être plus facile à comprendre que…
CAST(SomeReallyLongExpression
+ ThatMayEvenSpan
+ MultipleLines
AS SomeType
)
CAST(Column1 AS int)
est plus logique à lire que CONVERT(int, Column1)
même pour les expressions longues