Creare e gestire le viste logiche
In Bigtable, una vista logica è il risultato di una query SQL che funziona come una tabella virtuale su cui è possibile eseguire query con altre query SQL. I dati rimangono nella tabella di origine.
Questo documento descrive le visualizzazioni logiche e come creare ed eseguire operazioni su di esse. Per un confronto con le viste materializzate continue e le viste autorizzate, consulta Tabelle e viste.
Le viste logiche ti consentono di eseguire le seguenti operazioni con i tuoi dati Bigtable:
- Evita la ripetizione delle query: puoi archiviare e sviluppare la logica di mapping e cast delle colonne in una visualizzazione logica, che altre visualizzazioni logiche possono utilizzare invece di copiare e incollare la logica o doverla comprendere.
- Esegui l'integrazione con sistemi progettati per leggere da database relazionali: le viste logiche ti consentono di leggere i dati Bigtable come una tabella di database relazionale o una tabella Cassandra.
- Esegui la stessa visualizzazione logica su più tabelle: modificando la clausola
FROM
, puoi utilizzare la stessa visualizzazione per eseguire query su qualsiasi tabella nell'istanza Bigtable. - Fornisci un'interfaccia coerente: la tua applicazione può utilizzare una visualizzazione logica anche se la tabella di origine cambia.
- Limitare l'accesso in lettura a colonne o righe specifiche: puoi esporre solo i dati che vuoi consentire agli utenti di leggere, senza concedere loro l'accesso all'intera tabella.
Una vista logica è una risorsa a livello di istanza. Puoi creare una visualizzazione logica utilizzando Google Cloud CLI o l'editor di query Bigtable Studio nella console Google Cloud . Per eseguire query su una vista logica, puoi utilizzare l'editor di query di Bigtable Studio o una qualsiasi delle librerie client di Bigtable che supportano SQL.
Una vista logica ha le seguenti caratteristiche:
- Devi utilizzare le funzionalità SQL supportate da GoogleSQL per Bigtable
- Sola lettura
- Deve essere letto con SQL anziché con una chiamata a
ReadRows
- Può essere eseguita una query utilizzando una qualsiasi delle librerie client di Bigtable che supportano SQL
- Utilizza i diritti di definizione. Puoi eseguire query su una vista logica se disponi delle autorizzazioni per leggerla anche se non disponi dell'autorizzazione per leggere la tabella di origine.
La chiave di riga, il qualificatore di colonna e i valori di colonna che utilizzi per definire una vista logica vengono trattati come dati del servizio. Per questo motivo, non creare una visualizzazione logica utilizzando la chiave di riga, il qualificatore di colonna o i valori delle colonne che contengono informazioni sensibili. Per informazioni su come vengono gestiti i dati del servizio, consulta l'Google Cloud Informativa sulla privacy.
Prima di iniziare
Se prevedi di utilizzare gcloud CLI, segui questi passaggi:
-
Install the Google Cloud CLI.
-
Se utilizzi un provider di identità (IdP) esterno, devi prima accedere a gcloud CLI con la tua identità federata.
-
Per inizializzare gcloud CLI, esegui questo comando:
gcloud init
Ruoli obbligatori
Per lavorare con le visualizzazioni logiche, devi disporre delle seguenti autorizzazioni:
Per gestire le viste logiche:
- Per creare, aggiornare o eliminare viste logiche, devi disporre del ruolo
Bigtable Admin (
roles/bigtable.admin
) sull'istanza. - In alternativa, puoi chiedere all'amministratore di concederti le seguenti
autorizzazioni a livello di istanza:
- Crea:
bigtable.logicalViews.create
- Aggiorna:
bigtable.logicalViews.update
- Elimina:
bigtable.logicalViews.delete
- Crea:
Per visualizzare ed eseguire query sulle viste logiche:
- Per elencare o descrivere le viste logiche, devi disporre del ruolo Bigtable Reader (
roles/bigtable.reader
) nell'istanza. In alternativa, puoi chiedere all'amministratore di concederti le seguenti autorizzazioni a livello di istanza:
- Elenco:
bigtable.logicalViews.list
- Descrivi:
bigtable.logicalViews.get
- Elenco:
Per eseguire una query su una vista logica, devi disporre dell'autorizzazione
bigtable.logicalViews.readRows
per la vista logica.
Per creare una vista logica:
- Devi disporre almeno dell'autorizzazione
bigtable.tables.readRows
sulla tabella di origine.
Per concedere l'accesso in lettura a una visualizzazione specifica:
Puoi concedere a un utente l'autorizzazione a leggere una visualizzazione logica specifica, anche se non dispone di altre autorizzazioni Bigtable. Per farlo, utilizza una
condizione IAM per concedere l'autorizzazione bigtable.logicalViews.readRows
solo per quella vista:
- Concedi all'utente il ruolo
bigtable.reader
sul progetto. Crea una condizione IAM che limiti l'autorizzazione
bigtable.logicalViews.readRows
alla visualizzazione logica specifica. Ad esempio:resource.name == projects/PROJECT_ID/instances/INSTANCE_ID/logicalViews/VIEW
Sostituisci quanto segue:
PROJECT_ID
: il Google Cloud progetto in cui si trova l'istanza Bigtable.VIEW
: un ID lungo fino a 128 caratteri per la nuova visualizzazione logica. L'ID deve essere univoco tra gli ID tabella e gli ID vista nell'istanza.INSTANCE_ID
: l'ID dell'istanza in cui creare la visualizzazione logica.
Per saperne di più, consulta Gestire l'accesso alle risorse utilizzando le condizioni IAM.
Per saperne di più su tutti i ruoli e le autorizzazioni disponibili, consulta Controllo dell'controllo dell'accesso con IAM.
Creare una vista logica
Console
Apri l'elenco delle istanze Bigtable nella console Google Cloud .
Seleziona un'istanza.
Nel riquadro di navigazione, fai clic su Bigtable Studio.
Apri una nuova scheda facendo clic su
e poi scegliendo Editor.Nell'editor di query, scrivi la query. Se la query è SQL valido, viene visualizzato il messaggio Valido.
(Facoltativo) Per formattare l'istruzione in stile SQL, fai clic su Formatta.
Fai clic su Esegui. I risultati della query vengono visualizzati nella tabella Risultati.
Quando la query ti soddisfa, fai clic su Salva e poi scegli Salva vista.
Per saperne di più sull'utilizzo dell'editor di query, consulta Gestire i dati utilizzando Bigtable Studio.
gcloud
Per creare una vista logica, utilizza il comando
gcloud bigtable logical-views create
.
gcloud bigtable logical-views create VIEW \
--instance=INSTANCE --query=QUERY
Sostituisci quanto segue:
VIEW
: un ID lungo fino a 128 caratteri per la nuova visualizzazione logica. L'ID deve essere univoco tra gli ID tabella e gli ID vista nell'istanza.QUERY
: una query GoogleSQL valida per BigtableINSTANCE
: l'ID dell'istanza in cui creare la visualizzazione logica
Facoltativamente,
- Per proteggere la vista logica dall'eliminazione, aggiungi il flag
--deletion-protection
al comando. Se non applichi questa impostazione, la visualizzazione logica può essere eliminata. Puoi anche consentire esplicitamente l'eliminazione della vista logica aggiungendo--no-deletion-protection
. Per saperne di più, consulta la sezione Aggiornare una visualizzazione logica di questo documento.
Aggiorna una vista logica
Console
Non puoi aggiornare la protezione da eliminazione per una vista logica nella consoleGoogle Cloud . Per attivare o disattivare la protezione dall'eliminazione, utilizza Google Cloud CLI.
Apri l'elenco delle istanze Bigtable nella console Google Cloud .
Seleziona un'istanza dall'elenco.
Nel riquadro di navigazione, fai clic su Bigtable Studio. Nell'explorer viene visualizzato un elenco di visualizzazioni.
(Facoltativo) Vengono elencate le prime 10 visualizzazioni nell'istanza. Per visualizzarne altri 10, fai clic su Mostra altro.
Accanto alla visualizzazione da aggiornare, fai clic sul menu delle azioni more_vert, quindi fai clic su Visualizza definizione.
Modifica la query.
Fai clic su Esegui.
Dopo aver verificato che il riquadro dei risultati mostri i dati da includere nella visualizzazione, fai clic su Salva come.
Nella finestra di dialogo, inserisci l'ID della vista che hai modificato.
La finestra di dialogo mostra un messaggio che ti avvisa che stai sovrascrivendo la visualizzazione esistente.
Fai clic su Salva.
gcloud
Per aggiornare una vista logica in modo da eseguire una query diversa o modificare la protezione
dall'eliminazione, utilizza il
comando
gcloud bigtable logical-views update
. Devi specificare la query, la protezione da eliminazione o entrambe.
Per aggiornare la query di una vista logica:
gcloud bigtable logical-views update VIEW \
--instance=INSTANCE --query=QUERY
Per abilitare la protezione da eliminazione per una vista logica:
gcloud bigtable logical-views update VIEW \
--instance=INSTANCE \
--deletion-protection=true
Per disattivare la protezione da eliminazione per una vista logica:
gcloud bigtable logical-views update VIEW \
--instance=INSTANCE \
--deletion-protection=false
Sostituisci quanto segue:
VIEW
: l'ID della vista logica da aggiornareINSTANCE
: l'ID dell'istanza che contiene la vista logicaQUERY
: una query GoogleSQL valida
Eliminare una vista logica
Questa azione è definitiva.
Se una visualizzazione logica ha la protezione da eliminazione abilitata, non puoi eliminarla. Per eliminare una vista logica per cui è abilitata la protezione da eliminazione, devi aggiornarla per disabilitare la protezione da eliminazione. Per saperne di più, consulta la sezione Aggiornare una visualizzazione logica di questo documento.
Console
Apri l'elenco delle istanze Bigtable nella console Google Cloud .
Seleziona un'istanza dall'elenco.
Nel riquadro di navigazione, fai clic su Bigtable Studio. Nell'explorer viene visualizzato un elenco di visualizzazioni.
(Facoltativo) Vengono elencate le prime 10 visualizzazioni nell'istanza. Per visualizzarne altri 10, fai clic su Mostra altro.
Espandi Visualizzazioni.
Accanto alla visualizzazione che vuoi eliminare, fai clic sul menu azioni more_vert, quindi fai clic su Elimina.
gcloud
Per eliminare una vista logica, utilizza il
comando gcloud bigtable logical-views delete
.
gcloud bigtable logical-views delete VIEW \
--instance=INSTANCE
Sostituisci quanto segue:
VIEW
: l'ID della vista logica da aggiornareINSTANCE
: l'ID dell'istanza che contiene la vista logica
Recuperare un elenco di viste logiche per un'istanza
Puoi visualizzare un elenco delle viste logiche per un'istanza.
Console
Apri l'elenco delle istanze Bigtable nella console Google Cloud .
Seleziona un'istanza dall'elenco.
Nel riquadro di navigazione, fai clic su Bigtable Studio. Nell'explorer viene visualizzato un elenco di visualizzazioni.
(Facoltativo) Vengono elencate le prime 10 visualizzazioni nell'istanza. Per visualizzarne altri 10, fai clic su Mostra altro.
gcloud
Per visualizzare un elenco delle visualizzazioni logiche per un'istanza, utilizza il
comando gcloud bigtable logical-views list
.
gcloud bigtable logical-views list --instance=INSTANCE
Sostituisci INSTANCE
con l'ID istanza.
Descrivere una vista logica
Per ottenere dettagli su una visualizzazione logica, utilizza il comando gcloud bigtable logical-views
describe
.
gcloud bigtable logical-views describe VIEW \
--instance=INSTANCE
Il terminale mostra dettagli simili ai seguenti:
createTime: '2025-03-07T19:49:56.316578Z'
etag: W/"/v1/17919275593532352351"
name: projects/my-project/instances/my-instance/logicalViews/my-view
query: SELECT street FROM addresses
updateTime: '2025-03-07T19:49:56.316578Z'
deletion_protection: true
Esegui query su una vista logica
Dopo aver creato una vista logica, puoi eseguirvi query utilizzando SQL, proprio come faresti con una tabella normale. Puoi utilizzare le viste logiche nella clausola FROM
delle istruzioni SELECT
.
Nell'editor di query, inserisci una query GoogleSQL che faccia riferimento al nome della vista. Ad esempio, se la visualizzazione si chiama MyLogicalView
:
SELECT *
FROM MyLogicalView
LIMIT 100;
Per saperne di più sull'esecuzione di query SQL in Bigtable, consulta Eseguire query sui dati con SQL nell'editor query.
Passaggi successivi
- Panoramica di GoogleSQL per Bigtable
- Viste materializzate continue
- Panoramica delle viste autorizzate