Riferimento alle variabili di sistema

BigQuery supporta le seguenti variabili di sistema per le query multi-istruzione o all'interno delle sessioni. Puoi utilizzare le variabili di sistema per impostare o recuperare informazioni durante l'esecuzione delle query, in modo simile alle variabili del linguaggio procedurale definite dall'utente.

Nome Tipo Lettura e scrittura o sola lettura Descrizione
@@current_job_id STRING Sola lettura ID job del job attualmente in esecuzione. Nel contesto di una query multi-istruzione, questo restituisce il job responsabile dell'istruzione corrente, non l'intera query multi-istruzione.
@@dataset_id STRING Lettura e scrittura ID del set di dati predefinito nel progetto corrente. Questo ID viene utilizzato quando non viene specificato un set di dati per un progetto nella query. Puoi utilizzare l'istruzione SET per assegnare @@dataset_id a un altro ID set di dati nel progetto corrente. Le variabili di sistema @@dataset_project_id e @@dataset_id possono essere impostate e utilizzate insieme.
@@dataset_project_id STRING Lettura e scrittura ID del progetto predefinito utilizzato quando non ne viene specificato uno per un set di dati utilizzato nella query. Se @@dataset_project_id non è impostato o se è impostato su NULL, viene utilizzato il progetto di esecuzione delle query (@@project_id). Puoi utilizzare l'istruzione SET per assegnare @@dataset_project_id a un altro ID progetto. Le variabili di sistema @@dataset_project_id e @@dataset_id possono essere impostate e utilizzate insieme.
@@last_job_id STRING Sola lettura ID job dell'ultimo job da eseguire nella query multi-istruzione corrente, escluso quello attuale. Se la query multi-istruzione contiene CALL istruzioni, questo job potrebbe essere stato creato in una procedura diversa.
@@location STRING Lettura e scrittura La località in cui eseguire la query. @@location può essere impostato solo su un valore letterale stringa con una località valida. Un'istruzione SET @@location deve essere la prima istruzione in una query. Si verifica un errore se non corrisponde @@location a un'altra impostazione della posizione per la query. Puoi migliorare la latenza delle query che impostano @@location utilizzando la modalità di creazione dei job facoltativa. Puoi utilizzare la variabile di sistema @@location all'interno delle UDF SQL e delle funzioni di tabella.
@@project_id STRING Sola lettura ID del progetto utilizzato per eseguire la query corrente. Nel contesto di una procedura, @@project_id si riferisce al progetto che esegue la query multi-istruzione, non al progetto proprietario della procedura.
@@query_label STRING Lettura e scrittura Etichetta della query da associare ai job di query nella query o nella sessione corrente con più istruzioni. Se impostata in una query, tutte le query successive nel copione o nella sessione avranno questa etichetta. Se non viene impostato in una query, il valore di questa variabile di sistema è NULL. Per un esempio di come impostare questa variabile di sistema, consulta Associare i job di una sessione a un'etichetta.
@@reservation STRING Lettura e scrittura [Anteprima]. Specifica la prenotazione in cui viene eseguito il job. Deve essere nel seguente formato: projects/project_id/locations/location/reservations/reservation_id. La posizione della prenotazione deve corrispondere a quella in cui viene eseguita la query.
@@row_count INT64 Sola lettura Se utilizzata in una query con più istruzioni e l'istruzione precedente è DML, specifica il numero di righe modificate, inserite o eliminate a seguito di questa istruzione DML. Se l'istruzione precedente è un'istruzione MERGE, @@row_count rappresenta il numero totale combinato di righe inserite, rimosse ed eliminate. Questo valore è NULL se non si trova in una query con più istruzioni.
@@script.bytes_billed INT64 Sola lettura Byte totali fatturati finora nel job di query multi-istruzione attualmente in esecuzione. Questo valore è NULL se non è presente nel job.
@@script.bytes_processed INT64 Sola lettura Byte totali elaborati finora nel job di query con più istruzioni attualmente in esecuzione. Questo valore è NULL se non è presente nel job.
@@script.creation_time TIMESTAMP Sola lettura Ora di creazione del job di query con più istruzioni attualmente in esecuzione. Questo valore è NULL se non è presente nel job.
@@script.job_id STRING Sola lettura ID job del job di query multi-istruzione attualmente in esecuzione. Questo valore è NULL se non è presente nel job.
@@script.num_child_jobs INT64 Sola lettura Numero di job secondari attualmente completati. Questo valore è NULL se non è presente nel job.
@@script.slot_ms INT64 Sola lettura Numero di millisecondi di slot utilizzati finora dallo script. Questo valore è NULL se non è presente nel job.
@@session_id INT64 Sola lettura L'ID della sessione a cui è associata la query corrente.
@@time_zone STRING Lettura e scrittura Il fuso orario predefinito da utilizzare nelle funzioni SQL dipendenti dal fuso orario, quando non ne è specificato uno come argomento. @@time_zone può essere modificato utilizzando un'istruzione SET con qualsiasi nome di fuso orario valido. All'inizio di ogni script, @@time_zone inizia come "UTC".

Per la compatibilità con le versioni precedenti, le espressioni utilizzate in una clausola OPTIONS o FOR SYSTEM TIME AS OF vengono impostate per impostazione predefinita sul fuso orario America/Los_Angeles, mentre tutte le altre espressioni di data/ora vengono impostate per impostazione predefinita sul fuso orario UTC. Se @@time_zone è stato impostato in precedenza nella query multi-istruzione, il fuso orario scelto verrà applicato a tutte le espressioni di data/ora, incluse le clausole OPTIONS e FOR SYSTEM TIME AS OF.

Oltre alle variabili di sistema mostrate in precedenza, puoi utilizzare le variabili di sistema EXCEPTION durante l'esecuzione di una query con più istruzioni. Per saperne di più sulle variabili di sistema EXCEPTION, consulta l'istruzione del linguaggio procedurale BEGIN...EXCEPTION.

Esempi

Non puoi creare variabili di sistema, ma puoi sostituire il valore predefinito di alcune di queste:

SET @@dataset_project_id = 'MyProject';

La seguente query restituisce il fuso orario predefinito:

SELECT @@time_zone AS default_time_zone;
+-------------------+
| default_time_zone |
+-------------------+
| UTC               |
+-------------------+

Puoi utilizzare le variabili di sistema con le query DDL e DML. Ad esempio, ecco alcuni modi per utilizzare la variabile di sistema @@time_zone quando crei e aggiorni una tabella:

BEGIN
  CREATE TEMP TABLE MyTempTable
  AS SELECT @@time_zone AS default_time_zone;
END;
CREATE OR REPLACE TABLE MyDataset.MyTable(default_time_zone STRING)
  OPTIONS (description = @@time_zone);
UPDATE MyDataset.MyTable
SET default_time_zone = @@time_zone
WHERE TRUE;

Esistono alcuni casi in cui le variabili di sistema non possono essere utilizzate nelle query DDL e DML. Ad esempio, non puoi utilizzare una variabile di sistema come nome di progetto, set di dati o tabella. La seguente query genera un errore quando includi la variabile di sistema @@dataset_id in un percorso della tabella:

BEGIN
  CREATE TEMP TABLE @@dataset_id.MyTempTable (id STRING);
END;

Per altri esempi di come utilizzare le variabili di sistema nelle query con più istruzioni, consulta Impostare una variabile.

Per esempi di come utilizzare le variabili di sistema nelle sessioni, consulta la sezione Esempio di sessione.