Accéder aux données de l'historique
BigQuery vous permet d'utiliser les fonctionnalités temporelles pour accéder aux données stockées dans BigQuery qui ont été modifiées ou supprimées.
Interroger les données à un moment précis
Vous pouvez interroger les données historiques d'une table à tout moment dans la fenêtre temporelle en utilisant une clause FOR SYSTEM_TIME AS OF
. Cette clause prend une expression d'horodatage constante et fait référence à la version de la table active à cet horodatage. La table doit être stockée dans BigQuery. Il ne peut pas s'agir d'une table externe. Lorsque vous utilisez SYSTEM_TIME AS OF
, la taille de la table n'est pas limitée.
Par exemple, la requête suivante renvoie une version historique de la table d'une heure écoulée :
SELECT *
FROM `mydataset.mytable`
FOR SYSTEM_TIME AS OF TIMESTAMP_SUB(CURRENT_TIMESTAMP(), INTERVAL 1 HOUR);
Si l'horodatage spécifie une heure antérieure à la fenêtre de fonctionnalité temporelle ou avant la création de la table, la requête échoue et renvoie une erreur semblable à celle-ci :
Invalid snapshot time 1601168925462 for table myproject:mydataset.table1@1601168925462. Cannot read before 1601573410026.
Après avoir remplacé une table existante à l'aide de l'instruction CREATE OR REPLACE TABLE
, vous pouvez utiliser FOR SYSTEM_TIME AS OF
pour interroger la version précédente de la table.
Si la table a été supprimée, la requête échoue et renvoie une erreur semblable à celle-ci :
Not found: Table myproject:mydataset.table was not found in location LOCATION
Où LOCATION
est l'emplacement de l'ensemble de données.
Toutefois, vous pouvez restaurer la table en la copiant à partir d'un moment précis vers une nouvelle table, comme décrit dans ce document.
Restaurer une table à partir d'un moment précis
Vous pouvez restaurer une table à partir des données de l'historique en copiant les données de l'historique dans une table. La copie de données fonctionne même si la table a été supprimée ou a expiré, tant que vous la restaurez pendant la durée de la fenêtre de fonctionnalité temporelle.
Pour copier des données de l'historique à partir d'une table, ajoutez un décorateur au nom de la table à l'aide de l'une des syntaxes suivantes:
tableid@TIME
, oùTIME
est le nombre de millisecondes écoulées depuis l'époque Unix.tableid@-TIME_OFFSET
, oùTIME_OFFSET
est le décalage relatif par rapport à l'heure actuelle, en millisecondes.tableid@0
: spécifie les données de l'historique les plus anciennes disponibles.
Par exemple, la commande suivante de l'outil de ligne de commande bq permet de copier une table nommée table1
une heure auparavant dans une table nommée table1_restored
. La durée, -3600000
, est spécifiée en millisecondes à l'aide d'un décalage relatif.
bq cp mydataset.table1@-3600000 mydataset.table1_restored
Exécutez la commande suivante pour obtenir l'epoch Unix équivalent pour une heure que vous spécifiez:
date -d '2023-08-04 16:00:34.456789Z' +%s000
La commande suivante de l'outil de ligne de commande bq permet de copier une table nommée table1
dans une table nommée table1_restored
. Remplacez l'heure selon l'epoch UNIX 1691164834000
que vous avez reçue de la commande précédente.
bq cp mydataset.table1@1691164834000 mydataset.table1_restored
Pour en savoir plus, consultez la section Restaurer des tables supprimées.
Étapes suivantes
- En savoir plus sur les instantanés de table.