Aggiorna metadati snapshot tabella

Questo documento descrive come aggiornare la descrizione, la data di scadenza o i criteri di accesso per uno snapshot di tabella utilizzando la console Google Cloud, il comando bq update o l'API tables.patch. È destinata agli utenti che hanno familiarità con le tabelle e gli snapshot di tabelle in BigQuery.

Autorizzazioni e ruoli

Questa sezione descrive le autorizzazioni di Identity and Access Management (IAM) necessarie per aggiornare i metadati per uno snapshot della tabella e i ruoli IAM predefiniti che concedono queste autorizzazioni.

Autorizzazioni

Per aggiornare i metadati di uno snapshot di tabella, devi disporre della seguente autorizzazione:

Autorizzazione Risorsa
bigquery.tables.update Lo snapshot della tabella

Ruoli

I ruoli BigQuery predefiniti che forniscono l'autorizzazione richiesta sono i seguenti:

Role Risorsa
Uno dei seguenti:

bigquery.dataEditor
bigquery.dataOwner
biguqery.admin
Lo snapshot della tabella

Limitazioni

Puoi aggiornare i metadati di uno snapshot della tabella, ma non puoi aggiornarne i dati perché questi dati sono di sola lettura. Per aggiornare i dati di uno snapshot della tabella, devi prima ripristinare lo snapshot della tabella in una tabella standard, quindi aggiornare i dati della tabella standard. Per maggiori informazioni, consulta Ripristinare gli snapshot delle tabelle.

Aggiorna i metadati di uno snapshot della tabella

Puoi modificare la descrizione, la scadenza e i criteri di accesso di uno snapshot di tabella nello stesso modo in cui modifichi i metadati di una tabella standard. Alcuni esempi sono forniti nelle sezioni seguenti.

Aggiorna la descrizione

Puoi modificare la descrizione di uno snapshot della tabella utilizzando una delle seguenti opzioni:

Console

  1. Nella console Google Cloud, vai alla pagina BigQuery.

    Vai a BigQuery

  2. Nel riquadro Explorer, espandi i nodi del progetto e del set di dati dello snapshot della tabella che vuoi aggiornare.

  3. Fai clic sul nome dello snapshot della tabella.

  4. Nel riquadro snapshot visualizzato, fai clic sulla scheda Dettagli, quindi su Modifica dettagli.

  5. Nel campo Descrizione, aggiungi o aggiorna la descrizione per lo snapshot della tabella.

  6. Fai clic su Salva.

bq

Inserisci il comando seguente in Cloud Shell:

Vai a Cloud Shell

bq update \
--description="DESCRIPTION" \
PROJECT_ID:DATASET_NAME.SNAPSHOT_NAME

Sostituisci quanto segue:

  • DESCRIPTION: testo che descrive l'istantanea. Ad esempio, Snapshot after table schema change X..
  • PROJECT_ID: l'ID del progetto che contiene lo snapshot.
  • DATASET_NAME: il nome del set di dati che contiene lo snapshot.
  • SNAPSHOT_NAME: il nome dello snapshot.

API

Chiama il metodo tables.patch con i seguenti parametri:

Parametro Valore
projectId L'ID del progetto che contiene lo snapshot.
datasetId Il nome del set di dati che contiene lo snapshot.
tableId Il nome dello snapshot.
Campo description corpo della richiesta Testo che descrive l'istantanea. Ad esempio, Snapshot after table schema change X.

Preferisci il metodo tables.patch rispetto al metodo tables.update perché il metodo tables.update sostituisce l'intera risorsa Table.

Aggiorna la scadenza

Puoi modificare la scadenza di uno snapshot della tabella utilizzando una delle seguenti opzioni:

Console

  1. Nella console Google Cloud, vai alla pagina BigQuery.

    Vai a BigQuery

  2. Nel riquadro Explorer, espandi i nodi del progetto e del set di dati dello snapshot della tabella che vuoi aggiornare.

  3. Fai clic sul nome dello snapshot della tabella.

  4. Nel riquadro snapshot visualizzato, fai clic sulla scheda Dettagli, quindi su Modifica dettagli.

  5. Nel campo Data di scadenza, inserisci la nuova data di scadenza per lo snapshot della tabella.

  6. Fai clic su Salva.

bq

Inserisci il comando seguente in Cloud Shell:

Vai a Cloud Shell

bq update \
--expiration=EXPIRATION_TIME \
PROJECT_ID:DATASET_NAME.SNAPSHOT_NAME

Sostituisci quanto segue:

  • EXPIRATION_TIME: il numero di secondi dall'ora attuale alla scadenza.
  • PROJECT_ID: l'ID del progetto che contiene lo snapshot.
  • DATASET_NAME: il nome del set di dati che contiene lo snapshot.
  • SNAPSHOT_NAME: il nome dello snapshot.

API

Chiama il metodo tables.patch con i seguenti parametri:

Parametro Valore
projectId L'ID del progetto che contiene lo snapshot.
datasetId Il nome del set di dati che contiene lo snapshot.
tableId Il nome dello snapshot.
Campo expirationTime corpo della richiesta Il tempo di scadenza dello snapshot, in millisecondi dall'epoca.

Preferisci il metodo tables.patch rispetto al metodo tables.update perché il metodo tables.update sostituisce l'intera risorsa Table.

Aggiorna accesso

Puoi concedere a un utente l'accesso per visualizzare i dati in uno snapshot della tabella utilizzando una delle seguenti opzioni:

Console

  1. Nella console Google Cloud, vai alla pagina BigQuery.

    Vai a BigQuery

  2. Nel riquadro Explorer, espandi i nodi del progetto e del set di dati dello snapshot della tabella che vuoi aggiornare.

  3. Fai clic sul nome dello snapshot della tabella.

  4. Nel riquadro snapshot visualizzato, fai clic su Condividi e poi su Aggiungi entità.

  5. Nel riquadro Aggiungi entità visualizzato, inserisci l'identificatore dell'entità a cui vuoi concedere l'accesso allo snapshot della tabella.

  6. Nel menu a discesa Seleziona un ruolo, scegli BigQuery e poi Visualizzatore dati BigQuery.

  7. Fai clic su Salva.

bq

Inserisci il comando seguente in Cloud Shell:

Vai a Cloud Shell

bq add-iam-policy-binding \
    --member="user:PRINCIPAL" \
    --role="roles/bigquery.dataViewer" \
    PROJECT_ID:DATASET_NAME.SNAPSHOT_NAME

Sostituisci quanto segue:

  • PRINCIPAL: l'entità a cui vuoi concedere l'accesso allo snapshot della tabella.
  • PROJECT_ID: l'ID del progetto che contiene lo snapshot.
  • DATASET_NAME: il nome del set di dati che contiene lo snapshot.
  • SNAPSHOT_NAME: il nome dello snapshot.

API

Chiama il metodo tables.setIamPolicy con i seguenti parametri:

Parametro Valore
Resource

projects/PROJECT_ID/datasets/DATASET_NAME/tables/SNAPSHOT_NAME
Corpo della richiesta

{
      "policy": {
        "bindings": [
          {
            "members": [
              "user:PRINCIPAL"
            ],
            "role": "roles/bigquery.dataViewer"
          }
        ]
      }
    }

Sostituisci quanto segue:

  • PROJECT_ID: l'ID del progetto che contiene lo snapshot.
  • DATASET_NAME: il nome del set di dati che contiene lo snapshot.
  • SNAPSHOT_NAME: il nome dello snapshot.
  • PRINCIPAL: l'entità a cui vuoi concedere l'accesso allo snapshot della tabella.

Passaggi successivi