Accedere ai dati storici
BigQuery consente di eseguire query e ripristinare i dati archiviati in BigQuery che sono stati modificati o eliminati all'interno della finestra di time travel.
Eseguire query sui dati in un determinato momento
Puoi eseguire query sui dati storici di una tabella da qualsiasi momento all'interno della
finestra di time travel utilizzando una
FOR SYSTEM_TIME AS OF
clausola. Questa clausola accetta un'espressione timestamp costante e fa riferimento alla versione della tabella corrente in quel timestamp. La tabella deve essere archiviata in BigQuery; non può essere una tabella esterna. Non esiste un limite alle dimensioni della tabella quando si utilizza SYSTEM_TIME AS OF.
Ad esempio, la seguente query restituisce una versione storica della tabella di un'ora fa:
SELECT *
FROM `mydataset.mytable`
FOR SYSTEM_TIME AS OF TIMESTAMP_SUB(CURRENT_TIMESTAMP(), INTERVAL 1 HOUR);
Se il timestamp specifica un'ora precedente alla finestra di time travel o precedente alla creazione della tabella, la query non riesce e restituisce un errore simile al seguente:
Invalid snapshot time 1601168925462 for table myproject:mydataset.table1@1601168925462. Cannot read before 1601573410026.
Dopo aver sostituito una tabella esistente utilizzando l'istruzione CREATE OR REPLACE TABLE, puoi utilizzare FOR SYSTEM_TIME AS OF per eseguire query sulla versione precedente della tabella.
Se la tabella è stata eliminata, la query non riesce e restituisce un errore simile al seguente:
Not found: Table myproject:mydataset.table was not found in location LOCATION
Ripristinare una tabella da un determinato momento
Puoi ripristinare una tabella dai dati storici copiando i dati storici in una nuova tabella. La copia dei dati storici funziona anche se la tabella è stata eliminata o è scaduta, a condizione che tu la ripristini entro la durata della finestra di time travel.
Quando ripristini una tabella dai dati storici, tag dalla tabella di origine non vengono copiati nella tabella di destinazione. Anche le informazioni sul partizionamento della tabella non vengono copiate nella tabella di destinazione. Per ricreare lo schema di partizionamento della tabella originale, puoi visualizzare la richiesta di creazione della tabella iniziale in Cloud Logging e utilizzare queste informazioni per partizionare la tabella ripristinata.
Puoi ripristinare una tabella eliminata ma ancora all'interno della finestra di time travel
copiandola in una nuova tabella utilizzando il decoratore temporale @<time>.
Non puoi eseguire query su una tabella eliminata, anche se utilizzi un decoratore temporale. Devi prima ripristinarla.
Utilizza la seguente sintassi con il @<time> decoratore temporale:
tableid@TIMEdoveTIMEè il numero di millisecondi dall'epoca Unix.tableid@-TIME_OFFSETdoveTIME_OFFSETè l'offset relativo rispetto all'ora corrente, in millisecondi.tableid@0: specifica i dati storici più vecchi disponibili.
Per ripristinare una tabella, seleziona una delle seguenti opzioni:
Console
Non puoi annullare l'eliminazione di una tabella utilizzando la Google Cloud console.
bq
-
Nella Google Cloud console, attiva Cloud Shell.
Nella parte inferiore della Google Cloud console viene avviata una sessione di Cloud Shell e viene visualizzato un prompt della riga di comando. Cloud Shell è un ambiente shell con Google Cloud CLI già inclusa e installata e con valori già impostati per il progetto corrente. L'inizializzazione della sessione può richiedere alcuni secondi.
Per ripristinare una tabella, determina innanzitutto un timestamp Unix di quando la tabella esisteva (in millisecondi). Puoi utilizzare il comando Linux
dateper generare il timestamp Unix da un valore timestamp normale:date -d '2023-08-04 16:00:34.456789Z' +%s000
Quindi, utilizza il comando
bq copycon il@<time>decoratore di time travel per eseguire l'operazione di copia della tabella.Ad esempio, inserisci il seguente comando per copiare la tabella
mydataset.mytableal momento1418864998000in una nuova tabellamydataset.newtable.bq cp mydataset.mytable@1418864998000 mydataset.newtable
(Facoltativo) Fornisci il flag
--locatione imposta il valore sulla tua località.Puoi anche specificare un offset relativo. Il seguente esempio copia la versione di una tabella di un'ora fa:
bq cp mydataset.mytable@-3600000 mydataset.newtable
Go
Prima di provare questo esempio, segui le istruzioni di configurazione di Go nella guida rapida di BigQuery per l'utilizzo delle librerie client. Per saperne di più, consulta la documentazione di riferimento dell'Go API BigQuery.
Per eseguire l'autenticazione in BigQuery, configura le Credenziali predefinite dell'applicazione. Per saperne di più, vedi Configura l'autenticazione per le librerie client.
Java
Prima di provare questo esempio, segui le istruzioni di configurazione Java nella guida rapida di BigQuery per l'utilizzo delle librerie client. Per saperne di più, consulta la documentazione di riferimento dell'API Java BigQuery.
Per eseguire l'autenticazione in BigQuery, configura le Credenziali predefinite dell'applicazione. Per saperne di più, vedi Configura l'autenticazione per le librerie client.
Node.js
Prima di provare questo esempio, segui le istruzioni di configurazione Node.js nella guida rapida di BigQuery per l'utilizzo delle librerie client. Per saperne di più, consulta la documentazione di riferimento dell'Node.js API BigQuery.
Per eseguire l'autenticazione in BigQuery, configura le Credenziali predefinite dell'applicazione. Per saperne di più, vedi Configura l'autenticazione per le librerie client.
Python
Prima di provare questo esempio, segui le istruzioni di configurazione di Python nella guida rapida di BigQuery per l'utilizzo delle librerie client. Per saperne di più, consulta la documentazione di riferimento dell'API PythonBigQuery.
Per eseguire l'autenticazione in BigQuery, configura le Credenziali predefinite dell'applicazione. Per saperne di più, vedi Configura l'autenticazione per le librerie client.
Se prevedi di voler ripristinare una tabella in un secondo momento rispetto a quanto consentito dalla finestra di time travel, crea uno snapshot della tabella. Per saperne di più, vedi Introduzione agli snapshot delle tabelle.
Non puoi ripristinare direttamente una visualizzazione logica. Per saperne di più, vedi Ripristinare una visualizzazione.
Passaggi successivi
- Scopri di più sugli snapshot delle tabelle.
- Scopri di più sulla conservazione dei dati con time travel e fail-safe.
- Scopri di più sulla gestione delle tabelle.