Convertir un entier en timestamp ou date/heure GMT / locale
Noter ce cours :
Là où de nombreux SGBD (Systèmes de gestion de bases de données) proposent des fonctions simples de conversion de dates, SQL Server est un peu plus compliqué à appréhender. Pour vous éviter de longues recherches, voici quelques compilations de mes trouvailles pour convertir un timestamp en datetime ou, plus généralement, convertir un entier en date/heure locale ou GMT.
Pour l'ensemble de nos exemples, nous utiliserons une table alertes avec une colonne temps de type bigint. J'ai utilisé SQL Server 2012 dans ce tutoriel, mais les exemples devraient fonctionner avec SQL Server 2008.
Convertir une chaîne de caractères en entier
Normalement, vous devriez stocker vos timestamps dans des types appropriés, pas en Varchar, mais, peu importe, si vous êtes dans ce cas, vous devez d'abord convertir un varchar en nombre. On va utiliser la fonction CONVERT() de SQL Server :
SELECT convert(bigint, temps) AS date FROM alertes
A ce stade, vous obtenez des entiers de type bigint. Si votre champ est déjà de type bigint, vous pouvez sauter cette étape.
Convertir un entier de type bigint en date/heure GMT
L'heure GMT ne tient pas compte du décalage horaire. Pour effectuer ces conversions, nous aurons besoin de la fonction DATEADD().
SELECT dateadd(s, temps, '1-1-1970 00:00:00') FROM alertes;
En cas de soucis avec votre version de SQL Server, il vous faudra peut-être effectuer une conversion de type pour le paramètre de la fonction DATEADD() qui, normalement, est une expression de type datetime. Essayez alors la requête suivante :
SELECT dateadd(s, temps, CONVERT(datetime, '1-1-1970 00:00:00')) FROM alertes;
A ce stade, vous obtenez des dates au format GMT.
Convertir une date/heure GMT en date/heure locale
Maintenant que vous avez des dates au format GMT, vous souhaiterez surement convertir votre timestamp original en date/heure locale. SQL Server ne permet pas directement de le faire. Toutefois, nous allons ruser. La première étape consiste à récupérer la date/heure GMT et la date/heure locale, de faire la différence entre les deux pour obtenir le décalage horaire (ou OFFSET). On ajoutera ensuite ce décalage à notre date GMT, pour obtenir une date/heure locale.
La différence entre deux dates s'effectue avec la fonction DATEDIFF, dont le premier argument est l'intervalle utilisée (ici la seconde, symbole s).
SELECT DATEDIFF(second, GETUTCDATE(),GETDATE());
Nous obtenons ici un résultat de 7200 secondes de décalage (GMT +2h en France à l'heure d'été).
Il faut maintenant ajouter notre différence à la date GMT calculée précédemment. Pour ce faire, nous allons utiliser la fonction DATEADD() de SQL Server.
Le premier argument de la fonction DATEADD() corrrespond au type passé en second paramètre. En gros, nous avons calculé une différence en secondes, il faudra donc indiquer second.
SELECT DATEADD(second, DATEDIFF(second, GETUTCDATE(),GETDATE()), dateadd(s, temps, '1-1-1970 00:00:00')) FROM alertes;
A ce stade, vous vous retrouvez avec une date/heure locale.