Creare e utilizzare le tabelle in cluster
Questo documento descrive come creare e utilizzare tabelle in cluster in BigQuery. Per una panoramica del supporto delle tabelle in cluster in BigQuery, consulta Introduzione alle tabelle in cluster.
Creare tabelle in cluster
Puoi creare una tabella in cluster utilizzando i seguenti metodi:
Creare una tabella da un risultato di query:
- Esegui un'istruzione DDL
CREATE TABLE AS SELECT
. - Esegui una query che crea una tabella di destinazione in cluster.
- Esegui un'istruzione DDL
Utilizza un'istruzione DDL
CREATE TABLE
con una clausolaCLUSTER BY
contenente unclustering_column_list
.Esegui il comando
bq mk
dello strumento a riga di comando bq.Esegui chiamate al metodo API
tables.insert
.Carica i dati in BigQuery.
Utilizza le librerie client.
Denominazione delle tabelle
Quando crei una tabella in BigQuery, il nome della tabella deve essere univoco per ogni set di dati. Il nome della tabella può:
- Contenere caratteri con un totale massimo di 1024 byte UTF-8.
- Contenere caratteri Unicode nelle categorie L (lettera), M (segno), N (numero), Pc (connettore, incluso il trattino basso), Pd (trattino), Zs (spazio). Per ulteriori informazioni, consulta la sezione Categoria generale.
Di seguito sono riportati alcuni esempi di nomi di tabelle validi:
table 01
, ग्राहक
, 00_お客様
, étudiant-01
.
Avvertenze:
- I nomi delle tabelle sono sensibili alle maiuscole per impostazione predefinita.
mytable
eMyTable
possono coesistere nello stesso set di dati, a meno che non facciano parte di un set di dati con distinzione tra maiuscole e minuscole disattivata. - Alcuni nomi di tabelle e prefissi dei nomi di tabelle sono riservati. Se ricevi un errore che indica che il nome o il prefisso della tabella è riservato, seleziona un nome diverso e riprova.
Se includi più operatori punto (
.
) in una sequenza, gli operatori duplicati vengono rimossi implicitamente.Ad esempio:
project_name....dataset_name..table_name
Diventa:
project_name.dataset_name.table_name
Autorizzazioni obbligatorie
Per creare una tabella, devi disporre delle seguenti autorizzazioni IAM:
bigquery.tables.create
bigquery.tables.updateData
bigquery.jobs.create
Inoltre, potresti richiedere l'autorizzazione bigquery.tables.getData
per accedere ai dati che scrivi nella tabella.
Ciascuno dei seguenti ruoli IAM predefiniti include le autorizzazioni necessarie per creare una tabella:
roles/bigquery.dataEditor
roles/bigquery.dataOwner
roles/bigquery.admin
(include l'autorizzazionebigquery.jobs.create
)roles/bigquery.user
(include l'autorizzazionebigquery.jobs.create
)roles/bigquery.jobUser
(include l'autorizzazionebigquery.jobs.create
)
Inoltre, se disponi dell'autorizzazione bigquery.datasets.create
, puoi
creare e aggiornare le tabelle nei set di dati che crei.
Per ulteriori informazioni sui ruoli e sulle autorizzazioni IAM in BigQuery, vedi Ruoli e autorizzazioni predefiniti.
Crea una tabella in cluster vuota con una definizione dello schema
Specifichi le colonne di clustering quando crei una tabella in BigQuery. Dopo aver creato la tabella, puoi modificare le colonne di clustering. Per maggiori dettagli, consulta la sezione Modifica della specifica di clustering.
Le colonne di clustering devono essere colonne di primo livello, non ripetute e devono essere uno dei seguenti tipi di dati:
BIGNUMERIC
BOOL
DATE
DATETIME
GEOGRAPHY
INT64
NUMERIC
RANGE
STRING
TIMESTAMP
Puoi specificare fino a quattro colonne di clustering. Quando specifichi più colonne, l'ordine delle colonne determina l'ordinamento dei dati. Ad esempio, se la tabella è in cluster per le colonne a, b e c, i dati vengono ordinati nello stesso ordine: prima per la colonna a, poi per la colonna b e infine per la colonna c. Come best practice, posiziona per prima la colonna filtrata o aggregata più di frequente.
Anche l'ordine delle colonne di clustering influisce sul rendimento e sui prezzi delle query. Per ulteriori informazioni sulle best practice per le query per le tabelle in cluster, consulta la pagina Esecuzione di query sulle tabelle in cluster.
Per creare una tabella in cluster vuota con una definizione dello schema:
Console
Nella console Google Cloud , vai alla pagina BigQuery.
- Nel riquadro Explorer, espandi il progetto e seleziona un set di dati.
- Nella sezione Informazioni sul set di dati, fai clic su Crea tabella.
- Nel riquadro Crea tabella, specifica i seguenti dettagli:
- Nella sezione Origine, seleziona Tabella vuota nell'elenco Crea tabella da.
- Nella sezione Destinazione, specifica i seguenti dettagli:
- Per Set di dati, seleziona il set di dati in cui vuoi creare la tabella.
- Nel campo Table (Tabella), inserisci il nome della tabella che vuoi creare.
- Verifica che il campo Tipo di tabella sia impostato su Tabella nativa.
- Nella sezione Schema, inserisci la definizione dello schema.
Puoi inserire manualmente le informazioni sullo schema utilizzando uno dei
seguenti metodi:
- Opzione 1: fai clic su Modifica come testo e incolla lo schema sotto forma di
array JSON. Quando utilizzi un array JSON, generi lo schema utilizzando lo stesso processo di creazione di un file di schema JSON.
Per visualizzare lo schema di una tabella esistente in formato JSON, inserisci il seguente comando:
bq show --format=prettyjson dataset.table
- Opzione 2: fai clic su tipo e la modalità di ogni campo. Aggiungi campo e inserisci lo schema della tabella. Specifica il nome, il
- Opzione 1: fai clic su Modifica come testo e incolla lo schema sotto forma di
array JSON. Quando utilizzi un array JSON, generi lo schema utilizzando lo stesso processo di creazione di un file di schema JSON.
Per visualizzare lo schema di una tabella esistente in formato JSON, inserisci il seguente comando:
- Per Ordine di clustering, inserisci da uno a quattro nomi di colonne separati da virgole.
- (Facoltativo) Nella sezione Opzioni avanzate, se vuoi utilizzare una chiave di crittografia gestita dal cliente, seleziona l'opzione Utilizza una chiave di crittografia gestita dal cliente (CMEK). Per impostazione predefinita, BigQuery cripta i contenuti dei clienti archiviati at-rest utilizzando un Google-owned and Google-managed encryption key.
- Fai clic su Crea tabella.
SQL
Utilizza il comando CREATE TABLE
istruzione DDL con l'opzione CLUSTER BY
. L'esempio seguente crea una
tabella in cluster denominata myclusteredtable
in mydataset
:
Nella console Google Cloud , vai alla pagina BigQuery.
Nell'editor di query, inserisci la seguente istruzione:
CREATE TABLE mydataset.myclusteredtable ( customer_id STRING, transaction_amount NUMERIC ) CLUSTER BY customer_id OPTIONS ( description = 'a table clustered by customer_id');
Fai clic su
Esegui.
Per maggiori informazioni su come eseguire le query, consulta Eseguire una query interattiva.
bq
Utilizza il comando bq mk
con i seguenti flag:
--table
(o la scorciatoia-t
).--schema
. Puoi fornire la definizione dello schema della tabella in linea o utilizzare un file di schema JSON.--clustering_fields
. Puoi specificare fino a quattro colonne di clustering.
I parametri facoltativi includono --expiration
, --description
,
--time_partitioning_type
, --time_partitioning_field
,
--time_partitioning_expiration
, --destination_kms_key
e --label
.
Se stai creando una tabella in un progetto diverso da quello predefinito,
aggiungi l'ID progetto al set di dati nel seguente formato:
project_id:dataset
.
--destination_kms_key
non è dimostrato qui. Per informazioni sull'utilizzo di --destination_kms_key
, vedi Chiavi di crittografia gestite dal cliente.
Inserisci il comando seguente per creare una tabella in cluster vuota con una definizione dello schema:
bq mk \ --table \ --expiration INTEGER1 \ --schema SCHEMA \ --clustering_fields CLUSTER_COLUMNS \ --description "DESCRIPTION" \ --label KEY:VALUE,KEY:VALUE \ PROJECT_ID:DATASET.TABLE
Sostituisci quanto segue:
INTEGER1
: la durata predefinita, in secondi, della tabella. Il valore minimo è 3600 secondi (1 ora). La scadenza corrisponde all'ora UTC corrente più il valore intero. Se imposti il tempo di scadenza della tabella quando la crei, l'impostazione di scadenza della tabella predefinita del set di dati viene ignorata. Se imposti questo valore, la tabella viene eliminata dopo il periodo di tempo specificato.SCHEMA
: una definizione di schema incorporata nel formatoCOLUMN:DATA_TYPE,COLUMN:DATA_TYPE
o il percorso del file di schema JSON sulla macchina locale.CLUSTER_COLUMNS
: un elenco separato da virgole di un massimo di quattro colonne di clustering. L'elenco non può contenere spazi.DESCRIPTION
: una descrizione della tabella, tra virgolette.KEY:VALUE
: la coppia chiave-valore che rappresenta un'etichetta. Puoi inserire più etichette utilizzando un elenco separato da virgole.PROJECT_ID
: il tuo ID progetto.DATASET
: un set di dati nel tuo progetto.TABLE
: il nome della tabella che stai creando.
Quando specifichi lo schema nella riga di comando, non puoi includere un tipo RECORD
(STRUCT
), non puoi includere una descrizione della colonna e non puoi specificare la modalità della colonna. Tutte le modalità sono impostate su NULLABLE
per impostazione predefinita. Per
includere descrizioni, modalità e tipi di RECORD
, fornisci un file
dello schema JSON.
Esempi:
Inserisci il comando seguente per creare una tabella in cluster
denominata myclusteredtable
in mydataset
nel tuo progetto predefinito. La scadenza della tabella è impostata su 2.592.000 (1 mese di 30 giorni), la descrizione è impostata su
This is my clustered table
e l'etichetta è impostata su
organization:development
. Il comando utilizza la scorciatoia -t
invece di
--table
.
Lo schema è specificato inline come:
timestamp:timestamp,customer_id:string,transaction_amount:float
. Il
campo di clustering specificato customer_id
viene utilizzato per raggruppare la tabella.
bq mk \
-t \
--expiration 2592000 \
--schema 'timestamp:timestamp,customer_id:string,transaction_amount:float' \
--clustering_fields customer_id \
--description "This is my clustered table" \
--label org:dev \
mydataset.myclusteredtable
Inserisci il comando seguente per creare una tabella in cluster denominata
myclusteredtable
in myotherproject
, non nel tuo progetto predefinito. La
descrizione è impostata su This is my clustered table
e l'etichetta
è impostata su organization:development
. Il comando utilizza la scorciatoia -t
invece di
--table
. Questo comando non specifica una scadenza della tabella. Se il set di dati
ha una scadenza predefinita della tabella, questa viene applicata. Se il set di dati non ha una scadenza
della tabella predefinita, la tabella non scade mai.
Lo schema è specificato in un file JSON locale: /tmp/myschema.json
. Il campo
customer_id
viene utilizzato per raggruppare la tabella.
bq mk \
-t \
--expiration 2592000 \
--schema /tmp/myschema.json \
--clustering_fields=customer_id \
--description "This is my clustered table" \
--label org:dev \
myotherproject:mydataset.myclusteredtable
Dopo aver creato la tabella, puoi aggiornarne la descrizione e le etichette.
Terraform
Utilizza la risorsa
google_bigquery_table
.
Per eseguire l'autenticazione in BigQuery, configura le Credenziali predefinite dell'applicazione. Per saperne di più, vedi Configurare l'autenticazione per le librerie client.
Il seguente esempio crea una tabella denominata mytable
raggruppata
nelle colonne ID
e Created
:
Per applicare la configurazione di Terraform in un progetto Google Cloud , completa i passaggi nelle sezioni seguenti.
Prepara Cloud Shell
- Avvia Cloud Shell.
-
Imposta il progetto Google Cloud predefinito in cui vuoi applicare le configurazioni Terraform.
Devi eseguire questo comando una sola volta per progetto e puoi eseguirlo in qualsiasi directory.
export GOOGLE_CLOUD_PROJECT=PROJECT_ID
Le variabili di ambiente vengono sostituite se imposti valori espliciti nel file di configurazione Terraform.
Prepara la directory
Ogni file di configurazione di Terraform deve avere la propria directory (chiamata anche modulo radice).
-
In Cloud Shell, crea una directory e un nuovo file al suo interno. Il nome file deve avere l'estensione
.tf
, ad esempiomain.tf
. In questo tutorial, il file viene denominatomain.tf
.mkdir DIRECTORY && cd DIRECTORY && touch main.tf
-
Se stai seguendo un tutorial, puoi copiare il codice campione in ogni sezione o passaggio.
Copia il codice campione nel file
main.tf
appena creato.(Facoltativo) Copia il codice da GitHub. Questa operazione è consigliata quando lo snippet Terraform fa parte di una soluzione end-to-end.
- Rivedi e modifica i parametri di esempio da applicare al tuo ambiente.
- Salva le modifiche.
-
Inizializza Terraform. Devi effettuare questa operazione una sola volta per directory.
terraform init
(Facoltativo) Per utilizzare l'ultima versione del provider Google, includi l'opzione
-upgrade
:terraform init -upgrade
Applica le modifiche
-
Rivedi la configurazione e verifica che le risorse che Terraform creerà o
aggiornerà corrispondano alle tue aspettative:
terraform plan
Apporta le correzioni necessarie alla configurazione.
-
Applica la configurazione di Terraform eseguendo il comando seguente e inserendo
yes
al prompt:terraform apply
Attendi che Terraform visualizzi il messaggio "Apply complete!" (Applicazione completata).
- Apri il tuo Google Cloud progetto per visualizzare i risultati. Nella console Google Cloud , vai alle risorse nell'interfaccia utente per assicurarti che Terraform le abbia create o aggiornate.
API
Chiama il metodo tables.insert
con una risorsa tabella definita che specifica la proprietà clustering.fields
e la proprietà schema
.
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 ulteriori informazioni, consulta la documentazione di riferimento dell'API BigQuery Python.
Per eseguire l'autenticazione in BigQuery, configura le Credenziali predefinite dell'applicazione. Per saperne di più, vedi Configurare l'autenticazione per le librerie client.
Vai
Prima di provare questo esempio, segui le istruzioni di configurazione di Go nella guida rapida di BigQuery per l'utilizzo delle librerie client. Per ulteriori informazioni, consulta la documentazione di riferimento dell'API BigQuery Go.
Per eseguire l'autenticazione in BigQuery, configura le Credenziali predefinite dell'applicazione. Per saperne di più, vedi Configurare l'autenticazione per le librerie client.
Java
Prima di provare questo esempio, segui le istruzioni di configurazione di Java nella guida rapida di BigQuery per l'utilizzo delle librerie client. Per ulteriori informazioni, consulta la documentazione di riferimento dell'API BigQuery Java.
Per eseguire l'autenticazione in BigQuery, configura le Credenziali predefinite dell'applicazione. Per saperne di più, vedi Configurare l'autenticazione per le librerie client.
Crea una tabella in cluster da un risultato di query
Esistono due modi per creare una tabella in cluster da un risultato di query:
- Scrivi i risultati in una nuova tabella di destinazione e specifica le colonne di clustering.
- Utilizzando un'istruzione DDL
CREATE TABLE AS SELECT
. Per saperne di più su questo metodo, consulta la sezione Creazione di una tabella in cluster dal risultato di una query nella pagina Utilizzo delle istruzioni del linguaggio di definizione dei dati.
Puoi creare una tabella in cluster eseguendo query su una tabella partizionata o su una tabella non partizionata. Non puoi modificare una tabella esistente in una tabella in cluster utilizzando i risultati della query.
Quando crei una tabella in cluster da un risultato di query, devi utilizzare SQL standard. Al momento, l'SQL precedente non è supportato per l'esecuzione di query sulle tabelle in cluster o per la scrittura dei risultati delle query nelle tabelle in cluster.
SQL
Per creare una tabella in cluster da un risultato di query, utilizza l'istruzione DDL CREATE TABLE
con l'opzione CLUSTER BY
. L'esempio seguente crea una nuova
tabella in cluster in base a customer_id
eseguendo una query su una tabella non in cluster esistente:
Nella console Google Cloud , vai alla pagina BigQuery.
Nell'editor di query, inserisci la seguente istruzione:
CREATE TABLE mydataset.clustered_table ( customer_id STRING, transaction_amount NUMERIC ) CLUSTER BY customer_id AS ( SELECT * FROM mydataset.unclustered_table );
Fai clic su
Esegui.
Per maggiori informazioni su come eseguire le query, consulta Eseguire una query interattiva.
bq
Inserisci il seguente comando per creare una nuova tabella di destinazione in cluster da un risultato di query:
bq --location=LOCATION query \ --use_legacy_sql=false 'QUERY'
Sostituisci quanto segue:
LOCATION
: il nome della tua sede. Il flag--location
è facoltativo. Ad esempio, se utilizzi BigQuery nella regione di Tokyo, puoi impostare il valore del flag suasia-northeast1
. Puoi impostare un valore predefinito per la località utilizzando il file.bigqueryrc.QUERY
: una query nella sintassi GoogleSQL. Al momento, non puoi utilizzare SQL precedente per eseguire query sulle tabelle in cluster o per scrivere i risultati delle query nelle tabelle in cluster. La query può contenere un'istruzioneCREATE TABLE
DDL che specifica le opzioni per la creazione della tabella in cluster. Puoi utilizzare DDL differiti anziché specificare i singoli flag della riga di comando.
Esempi:
Inserisci il seguente comando per scrivere i risultati della query in una tabella di destinazione
in cluster denominata myclusteredtable
in mydataset
. mydataset
si trova nel tuo progetto predefinito. La query recupera i dati da una tabella non partizionata:
mytable. La colonna customer_id
della tabella viene utilizzata per raggruppare
la tabella. La colonna timestamp
della tabella viene utilizzata per creare una tabella partizionata.
bq query --use_legacy_sql=false \
'CREATE TABLE
mydataset.myclusteredtable
PARTITION BY
DATE(timestamp)
CLUSTER BY
customer_id
AS (
SELECT
*
FROM
`mydataset.mytable`
);'
API
Per salvare i risultati della query in una tabella in cluster,
chiama il metodo jobs.insert
,
configura un
job query
e includi un'istruzione DDL CREATE TABLE
che crea la tabella in cluster.
Specifica la tua posizione nella proprietà location
nella sezione jobReference
della risorsa di lavoro.
Creare una tabella in cluster durante il caricamento dei dati
Puoi creare una tabella in cluster specificando le colonne di clustering quando carichi i dati in una nuova tabella. Non è necessario creare una tabella vuota prima di caricarvi i dati. Puoi creare la tabella in cluster e caricare i dati contemporaneamente.
Per ulteriori informazioni sul caricamento dei dati, vedi Caricare i dati in BigQuery.
Per definire il clustering durante la definizione di un job di caricamento:
SQL
Utilizza l'istruzione LOAD DATA
.
Il seguente esempio carica i dati AVRO per creare una tabella partizionata
in base al campo transaction_date
e raggruppata in cluster in base al campo customer_id
.
Inoltre, configura le partizioni in modo che scadano dopo tre giorni.
Nella console Google Cloud , vai alla pagina BigQuery.
Nell'editor di query, inserisci la seguente istruzione:
LOAD DATA INTO mydataset.mytable PARTITION BY transaction_date CLUSTER BY customer_id OPTIONS ( partition_expiration_days = 3) FROM FILES( format = 'AVRO', uris = ['gs://bucket/path/file.avro']);
Fai clic su
Esegui.
Per maggiori informazioni su come eseguire le query, consulta Eseguire una query interattiva.
API
Per definire una configurazione di clustering durante la creazione di una tabella tramite un job di caricamento, puoi compilare le proprietà Clustering
per la tabella.
Vai
Prima di provare questo esempio, segui le istruzioni di configurazione di Go nella guida rapida di BigQuery per l'utilizzo delle librerie client. Per ulteriori informazioni, consulta la documentazione di riferimento dell'API BigQuery Go.
Per eseguire l'autenticazione in BigQuery, configura le Credenziali predefinite dell'applicazione. Per saperne di più, vedi Configurare l'autenticazione per le librerie client.
Java
Prima di provare questo esempio, segui le istruzioni di configurazione di Java nella guida rapida di BigQuery per l'utilizzo delle librerie client. Per ulteriori informazioni, consulta la documentazione di riferimento dell'API BigQuery Java.
Per eseguire l'autenticazione in BigQuery, configura le Credenziali predefinite dell'applicazione. Per saperne di più, vedi Configurare 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 ulteriori informazioni, consulta la documentazione di riferimento dell'API BigQuery Python.
Per eseguire l'autenticazione in BigQuery, configura le Credenziali predefinite dell'applicazione. Per saperne di più, vedi Configurare l'autenticazione per le librerie client.
Controllare l'accesso alle tabelle in cluster
Per configurare l'accesso a tabelle e viste, puoi concedere un ruolo IAM a un'entità ai seguenti livelli, elencati in ordine di intervallo di risorse consentite (dalla più grande alla più piccola):
- un livello elevato nella Google Cloud gerarchia delle risorse, ad esempio il livello di progetto, cartella o organizzazione
- il livello del set di dati
- a livello di tabella o visualizzazione
Puoi anche limitare l'accesso ai dati all'interno delle tabelle utilizzando i seguenti metodi:
L'accesso a qualsiasi risorsa protetta da IAM è cumulativo. Ad esempio, se un'entità non ha accesso a un livello elevato, ad esempio un progetto, puoi concederle l'accesso a livello di set di dati e l'entità avrà accesso alle tabelle e alle viste nel set di dati. Allo stesso modo, se l'entità non ha accesso a livello di progetto o set di dati, puoi concederle l'accesso a livello di tabella o vista.
La concessione di ruoli IAM a un livello superiore nella Google Cloud gerarchia delle risorse come il progetto, la cartella o l'organizzazione consente all'entità di accedere a un ampio insieme di risorse. Ad esempio, se concedi un ruolo a un'entità a livello di progetto, questa entità avrà autorizzazioni che si applicano a tutti i set di dati del progetto.
La concessione di un ruolo a livello di set di dati specifica le operazioni che un'entità è autorizzata a eseguire su tabelle e viste in quel set di dati specifico, anche se l'entità non ha accesso a un livello superiore. Per informazioni sulla configurazione dei controlli dell'accesso a livello di set di dati, consulta Controllare l'accesso ai set di dati.
La concessione di un ruolo a livello di tabella o vista specifica le operazioni che un'entità è autorizzata a eseguire su tabelle e viste specifiche, anche se l'entità non ha accesso a un livello superiore. Per informazioni sulla configurazione dei controlli dell'accesso a livello di tabella, consulta Controllo dell'accesso a tabelle e viste.
Puoi anche creare ruoli personalizzati IAM. Se crei un ruolo personalizzato, le autorizzazioni che concedi dipendono dalle operazioni specifiche che vuoi che l'entità sia in grado di eseguire.
Non puoi impostare un'autorizzazione "Nega" su qualsiasi risorsa protetta da IAM.
Per saperne di più su ruoli e autorizzazioni, consulta la sezione Informazioni sui ruoli nella documentazione di IAM e la sezione Ruoli e autorizzazioni IAM di BigQuery.
Utilizzare le tabelle in cluster
Ottenere informazioni sulle tabelle in cluster
Puoi ottenere informazioni sulle tabelle nei seguenti modi:
- Utilizzo della console Google Cloud .
- Utilizzo del comando
bq show
dello strumento a riga di comando bq. - Chiamata del metodo API
tables.get
. - Query sulle visualizzazioni di
INFORMATION_SCHEMA
.
Autorizzazioni obbligatorie
Come minimo, per ottenere informazioni sulle tabelle, devi disporre delle autorizzazioni
bigquery.tables.get
. I seguenti ruoli IAM predefiniti includono le autorizzazioni bigquery.tables.get
:
bigquery.metadataViewer
bigquery.dataViewer
bigquery.dataOwner
bigquery.dataEditor
bigquery.admin
Inoltre, se un utente dispone delle autorizzazioni bigquery.datasets.create
, quando crea un set di dati, gli viene concesso l'accesso bigquery.dataOwner
.
L'accesso bigquery.dataOwner
consente all'utente di ottenere informazioni sulle tabelle in un set di dati.
Per saperne di più sui ruoli e sulle autorizzazioni IAM in BigQuery, consulta Ruoli e autorizzazioni predefiniti.
Recupero delle informazioni sulle tabelle in cluster
Per visualizzare informazioni su una tabella in cluster:
Console
Nella console Google Cloud , vai al riquadro Risorse. Fai clic sul nome del set di dati per espanderlo, poi fai clic sul nome della tabella che vuoi visualizzare.
Fai clic su Dettagli. Questa pagina mostra i dettagli della tabella, incluse le colonne di clustering.
SQL
Per le tabelle in cluster, puoi eseguire query sulla colonna CLUSTERING_ORDINAL_POSITION
nella vista INFORMATION_SCHEMA.COLUMNS
per trovare l'offset con indice 1 della colonna all'interno delle colonne di clustering della tabella:
Nella console Google Cloud , vai alla pagina BigQuery.
Nell'editor di query, inserisci la seguente istruzione:
CREATE TABLE mydataset.data (column1 INT64, column2 INT64) CLUSTER BY column1, column2; SELECT column_name, clustering_ordinal_position FROM mydataset.INFORMATION_SCHEMA.COLUMNS;
Fai clic su
Esegui.
Per maggiori informazioni su come eseguire le query, consulta Eseguire una query interattiva.
La posizione ordinale del clustering è 1 per column1
e 2 per column2
.
Altri metadati della tabella sono disponibili tramite le visualizzazioni TABLES
, TABLE_OPTIONS
,
COLUMNS
e COLUMN_FIELD_PATH
in INFORMATION_SCHEMA
.
bq
Esegui il comando bq show
per visualizzare tutte le informazioni della tabella. Utilizza il flag
--schema
per visualizzare solo le informazioni sullo schema della tabella. Il flag --format
può essere utilizzato per controllare l'output.
Se stai recuperando informazioni su una tabella in un progetto diverso da quello predefinito, aggiungi l'ID progetto al set di dati nel seguente formato: project_id:dataset
.
bq show \ --schema \ --format=prettyjson \ PROJECT_ID:DATASET.TABLE
Sostituisci quanto segue:
PROJECT_ID
: il tuo ID progettoDATASET
: il nome del set di datiTABLE
: il nome della tabella
Esempi:
Inserisci questo comando per visualizzare tutte le informazioni su
myclusteredtable
in mydataset
. mydataset
nel progetto predefinito.
bq show --format=prettyjson mydataset.myclusteredtable
L'output dovrebbe essere simile al seguente:
{ "clustering": { "fields": [ "customer_id" ] }, ... }
API
Chiama il metodo bigquery.tables.get
e fornisci eventuali parametri pertinenti.
Elenca le tabelle in cluster in un set di dati
Puoi elencare le tabelle in cluster nei set di dati nei seguenti modi:
- Utilizzo della console Google Cloud .
- Utilizzo del comando
bq ls
dello strumento a riga di comando bq. - Chiamata al metodo dell'API
tables.list
. - Utilizzo delle librerie client.
- Eseguire query sulla colonna
CLUSTERING_ORDINAL_POSITION
nella visualizzazioneINFORMATION_SCHEMA.COLUMNS
.
Le autorizzazioni richieste per elencare le tabelle in cluster e i passaggi per elencarle sono gli stessi delle tabelle standard. Per ulteriori informazioni sull'elenco delle tabelle, vedi Elenco delle tabelle in un set di dati.
Modificare la specifica di clustering
Puoi modificare o rimuovere le specifiche di clustering di una tabella oppure modificare l'insieme di colonne in cluster in una tabella in cluster. Questo metodo di aggiornamento del set di colonne di clustering è utile per le tabelle che utilizzano inserimenti di streaming continui perché non possono essere facilmente scambiate con altri metodi.
Segui questi passaggi per applicare una nuova specifica di clustering a tabelle non partizionate o partizionate.
Nello strumento bq, aggiorna la specifica di clustering della tabella in modo che corrisponda al nuovo clustering:
bq update --clustering_fields=CLUSTER_COLUMN DATASET.ORIGINAL_TABLE
Sostituisci quanto segue:
CLUSTER_COLUMN
: la colonna su cui stai eseguendo il clustering, ad esempiomycolumn
DATASET
: il nome del set di dati contenente la tabella, ad esempiomydataset
ORIGINAL_TABLE
: il nome della tabella originale, ad esempiomytable
Puoi anche chiamare il metodo API
tables.update
otables.patch
per modificare la specifica di clustering.Per raggruppare tutte le righe in base alla nuova specifica di clustering, esegui la seguente istruzione
UPDATE
:UPDATE DATASET.ORIGINAL_TABLE SET CLUSTER_COLUMN=CLUSTER_COLUMN WHERE true
Sicurezza delle tabelle
Per controllare l'accesso alle tabelle in BigQuery, vedi Controllare l'accesso alle risorse con IAM.
Passaggi successivi
- Per informazioni sull'esecuzione di query sulle tabelle in cluster, consulta Esecuzione di query sulle tabelle in cluster.
- Per una panoramica del supporto delle tabella partizionata in BigQuery, consulta Introduzione alle tabelle partizionate.
- Per scoprire come creare tabelle partizionate, consulta Creazione di tabelle partizionate.
- Per una panoramica di
INFORMATION_SCHEMA
, vai a Introduzione a BigQueryINFORMATION_SCHEMA
.