Riferimento alle procedure di sistema
BigQuery supporta le seguenti procedure di sistema, che possono essere utilizzate in modo simile alle procedure archiviate create dall'utente.
BQ.ABORT_SESSION
Sintassi
CALL BQ.ABORT_SESSION([session_id]);
Description
Termina la sessione corrente.
Facoltativamente, puoi specificare l'ID sessione, che consente di terminare una sessione se la procedura di sistema non viene chiamata da quella sessione.
Per ulteriori informazioni, consulta Chiusura delle sessioni.
BQ.JOBS.CANCEL
Sintassi
CALL BQ.JOBS.CANCEL(job);
Description
Annulla un job in esecuzione.
Specifica il job come stringa con il formato '[project_id.]job_id'
. Se esegui questa procedura di sistema da un progetto diverso dal job, devi includere l'ID progetto. Devi eseguire la procedura nella stessa località del job.
Per ulteriori informazioni, consulta Annullamento di un job.
BQ.REFRESH_EXTERNAL_METADATA_CACHE
Sintassi
CALL BQ.REFRESH_EXTERNAL_METADATA_CACHE(table_name [, [subdirectory_uri, …]]);
Description
Aggiorna la cache dei metadati di una tabella BigLake o di una tabella di oggetti.
Questa procedura non riesce se viene eseguita su una tabella in cui la modalità di memorizzazione nella cache dei metadati è impostata su AUTOMATIC
.
Per eseguire questa procedura di sistema, devi disporre delle autorizzazioni bigquery.tables.update
e bigquery.tables.updateData
.
Specifica il nome della tabella come stringa con il formato '[project_id.]dataset.table'
. Se esegui questa procedura di sistema da un progetto diverso da quello della tabella, devi includere l'ID progetto.
Per le tabelle BigLake, puoi facoltativamente specificare una o più sottodirectory della directory dei dati della tabella in Cloud Storage nel formato 'gs://table_data_directory/subdirectory/.../'
.
In questo modo puoi aggiornare solo i metadati della tabella da queste sottodirectory,
evitando così l'elaborazione non necessaria dei metadati.
Esempi
Per aggiornare tutti i metadati di una tabella:
CALL BQ.REFRESH_EXTERNAL_METADATA_CACHE('myproject.test_db.test_table')
Per aggiornare selettivamente i metadati per una tabella BigLake:
CALL BQ.REFRESH_EXTERNAL_METADATA_CACHE('myproject.test_db.test_table', ['gs://source/uri/sub/path/d1/', 'gs://source/uri/sub/path/d2/'])
Limitazione
L'aggiornamento della cache dei metadati non è supportato per le tabelle a cui fanno riferimento set di dati collegati su set di dati esterni.
BQ.REFRESH_MATERIALIZED_VIEW
Sintassi
CALL BQ.REFRESH_MATERIALIZED_VIEW(view_name);
Description
Aggiorna una vista materializzata.
Specifica il nome della vista materializzata come stringa con il formato
'[project_id.]dataset.table'
. Se esegui questa procedura di sistema da un progetto diverso dalla vista materializzata, devi includere l'ID progetto.
Per maggiori informazioni, consulta Aggiornamento manuale.