Restaurer les tables supprimées
Ce document explique comment restaurer (ou récupérer) une table supprimée dans BigQuery. Vous pouvez restaurer une table supprimée pendant la période spécifiée pour l'ensemble de données, y compris les suppressions explicites et implicites dues à l'expiration de la table. Vous pouvez également configurer la fenêtre de fonctionnalité temporelle.
Pour savoir comment restaurer un ensemble de données ou un instantané supprimé, consultez les ressources suivantes :
La période temporelle peut durer entre deux et sept jours. Une fois la fenêtre de fonctionnalité temporelle expirée, BigQuery offre une période de sécurité pendant laquelle les données supprimées sont automatiquement conservées pendant sept jours supplémentaires. Une fois le délai de sécurité écoulé, il n'est plus possible de restaurer une table, quelle que soit la méthode utilisée, y compris pour ouvrir une demande d'assistance.
Avant de commencer
Assurez-vous de disposer des autorisations IAM (Identity and Access Management) nécessaires pour restaurer une table supprimée.
Rôles requis
Pour obtenir les autorisations nécessaires pour restaurer une table supprimée, demandez à votre administrateur de vous accorder le rôle IAM Utilisateur BigQuery (roles/bigquery.user) sur le projet.
Pour en savoir plus sur l'attribution de rôles, consultez Gérer l'accès aux projets, aux dossiers et aux organisations.
Vous pouvez également obtenir les autorisations requises avec des rôles personnalisés ou d'autres rôles prédéfinis.
Restaurer un tableau
Vous pouvez restaurer une table à partir des données de l'historique en copiant les données de l'historique dans une nouvelle table. La copie des données historiques 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.
Lorsque vous restaurez une table à partir de données historiques, les tags de la table source ne sont pas copiés dans la table de destination. Les informations de partitionnement de la table ne sont pas non plus copiées dans la table de destination. Pour recréer le schéma de partitionnement de la table d'origine, vous pouvez consulter la demande de création de table initiale dans Cloud Logging et utiliser ces informations pour partitionner la table restaurée.
Vous pouvez restaurer une table supprimée, mais toujours dans la fenêtre temporelle, en copiant la table dans une nouvelle table, à l'aide du décorateur d'heure @<time>.
Vous ne pouvez pas interroger une table supprimée, même si vous utilisez un décorateur d'heure. Vous devez d'abord le restaurer.
Utilisez la syntaxe suivante avec le décorateur de temps @<time> :
tableid@TIME, oùTIMEest le nombre de millisecondes écoulées depuis l'époque Unix.tableid@-TIME_OFFSET, oùTIME_OFFSETest 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.
Pour restaurer une table, sélectionnez l'une des options suivantes :
Console
Vous ne pouvez pas annuler la suppression d'une table à l'aide de la console Google Cloud .
bq
-
In the Google Cloud console, activate Cloud Shell.
At the bottom of the Google Cloud console, a Cloud Shell session starts and displays a command-line prompt. Cloud Shell is a shell environment with the Google Cloud CLI already installed and with values already set for your current project. It can take a few seconds for the session to initialize.
Pour restaurer une table, commencez par déterminer un horodatage UNIX (en millisecondes) correspondant à la période d'existence de la table. Vous pouvez utiliser la commande Linux
datepour générer l'horodatage Unix à partir d'une valeur d'horodatage standard :date -d '2023-08-04 16:00:34.456789Z' +%s000
Exécutez ensuite la commande
bq copyavec le décorateur de fonctionnalité temporelle@<time>pour effectuer l'opération de copie de table.Par exemple, saisissez la commande suivante pour copier la table
mydataset.mytableau moment1418864998000dans une nouvelle tablemydataset.newtable.bq cp mydataset.mytable@1418864998000 mydataset.newtable
(Facultatif) Spécifiez l'option
--locationet définissez la valeur correspondant à votre emplacement.Vous pouvez également spécifier un décalage relatif. L'exemple suivant copie la version d'une table d'il y a une heure :
bq cp mydataset.mytable@-3600000 mydataset.newtable
Go
Avant d'essayer cet exemple, suivez les instructions de configuration pour Go du guide de démarrage rapide de BigQuery : Utiliser les bibliothèques clientes. Pour en savoir plus, consultez la documentation de référence de l'API BigQuery pour Go.
Pour vous authentifier auprès de BigQuery, configurez le service Identifiants par défaut de l'application. Pour en savoir plus, consultez la page Configurer l'authentification pour les bibliothèques clientes.
Java
Avant d'essayer cet exemple, suivez les instructions de configuration pour Java du guide de démarrage rapide de BigQuery : Utiliser les bibliothèques clientes. Pour en savoir plus, consultez la documentation de référence de l'API BigQuery pour Java.
Pour vous authentifier auprès de BigQuery, configurez le service Identifiants par défaut de l'application. Pour en savoir plus, consultez la page Configurer l'authentification pour les bibliothèques clientes.
Node.js
Avant d'essayer cet exemple, suivez les instructions de configuration pour Node.js du guide de démarrage rapide de BigQuery : Utiliser les bibliothèques clientes. Pour en savoir plus, consultez la documentation de référence de l'API BigQuery pour Node.js.
Pour vous authentifier auprès de BigQuery, configurez le service Identifiants par défaut de l'application. Pour en savoir plus, consultez la page Configurer l'authentification pour les bibliothèques clientes.
Python
Avant d'essayer cet exemple, suivez les instructions de configuration pour Python du guide de démarrage rapide de BigQuery : Utiliser les bibliothèques clientes. Pour en savoir plus, consultez la documentation de référence de l'API BigQuery pour Python.
Pour vous authentifier auprès de BigQuery, configurez le service Identifiants par défaut de l'application. Pour en savoir plus, consultez la page Configurer l'authentification pour les bibliothèques clientes.
Si vous prévoyez de restaurer une table ultérieurement à ce qui est autorisé par la fenêtre temporelle, créez un instantané de la table. Pour en savoir plus, consultez la page Présentation des instantanés de table.
Vous ne pouvez pas restaurer directement une vue logique. Pour en savoir plus, consultez Restaurer une vue.
Résoudre les problèmes de récupération de tables
Interroger la table supprimée à l'aide d'un code temporel passé
Vous ne pouvez pas restaurer les données d'une table en interrogeant une table supprimée dans le passé à l'aide d'un décorateur de code temporel ni en utilisant FOR SYSTEM_TIME AS OF pour enregistrer le résultat dans une table de destination. L'utilisation de l'une ou l'autre de ces méthodes génère l'erreur suivante :
Not found: Table myproject:mydataset.table was not found in location LOCATION
Pour copier la table, suivez plutôt la procédure décrite dans Restaurer une table.
Erreur : VPC Service Controls: Request is prohibited by organization's policy
Lorsque vous essayez d'exécuter la commande de copie depuis Google Cloud Shell, vous pouvez rencontrer une erreur semblable à celle-ci :
BigQuery error in cp operation: VPC Service Controls: Request is prohibited by organization's policy
L'utilisation de Cloud Shell depuis la console Google Cloud avec VPC-SC n'est pas prise en charge, car elle est traitée comme une requête en dehors des périmètres de service et l'accès aux données protégées par VPC Service Controls est refusé. Pour contourner ce problème, lancez et connectez-vous à Cloud Shell en local avec la Google Cloud CLI.
Erreur : Latest categories are incompatible with schema
Si vous exécutez la commande de copie depuis Google Cloud Shell, vous pouvez recevoir une erreur semblable à la suivante :
Latest categories are incompatible with schema at TIMESTAMP
Plusieurs raisons peuvent expliquer cette erreur :
- Le schéma de la table de destination est différent de celui de la table d'origine (les colonnes supplémentaires sont autorisées tant qu'elles ne sont associées à aucun tag avec stratégie au niveau de la colonne).
- Les tags de règles au niveau des colonnes de la table de destination sont configurés différemment de ceux de la table source.
Pour résoudre cette erreur :
- Assurez-vous que le schéma de la table de destination est identique et qu'aucune colonne de la table d'origine ne manque dans la table de destination.
- Supprimez tous les tags avec stratégie au niveau des colonnes de la table de destination qui ne figurent pas dans le schéma de la table d'origine.
Erreur : BigQuery error in cp operation: Invalid time travel timestamp
Si vous exécutez la commande bq copy depuis Google Cloud Shell, vous pouvez recevoir une erreur semblable à la suivante :
BigQuery error in cp operation: Invalid time travel timestamp 1744343690000 for table PROJECT_ID:DATASET_ID.TABLE_ID@1744343690000. Cannot read before 1744843691075
Cette erreur indique que vous essayez de récupérer des données à partir de l'état de la table avant la fenêtre de fonctionnalité temporelle ou avant la création de la table. Cette fonctionnalité n'est pas disponible. Le message d'erreur contient le dernier code temporel pouvant être utilisé pour lire les données du tableau. Utilisez le code temporel de l'erreur dans la commande bq copy.
Cette erreur peut également se produire lorsque vous fournissez une valeur d'horodatage négative, par exemple TABLE@-1744963620000. Utilisez plutôt un décalage temporel qui peut être utilisé avec le signe -.
BigQuery error in cp operation: Invalid time travel timestamp 584878816 for table PROJECT_ID:DATASET_ID.TABLE_ID@584878816. Cannot read before 1744843691075
Ce message d'erreur indique que la commande bq cp contient une valeur d'horodatage négative en tant que décalage et que vous avez tenté de lire le tableau à CURRENT_TIMESTAMP - PROVIDED TIMESTAMP. Cette valeur est normalement un code temporel en 1970. Pour contourner ce problème, vérifiez les valeurs de décalage ou d'horodatage lorsque vous définissez la valeur du décorateur de tableau et utilisez le signe - de manière appropriée.
Étapes suivantes
- Découvrez comment créer et utiliser des tables.
- Découvrez comment gérer des tables.
- Découvrez comment modifier des schémas de table.
- Découvrez comment utiliser les données de tables.