Aggiunta di etichette alle risorse

Questa pagina spiega come etichettare le risorse BigQuery.

Prima di iniziare

Concede ruoli IAM (Identity and Access Management) che concedono agli utenti le autorizzazioni necessarie per eseguire ciascuna attività in questo documento. Qualsiasi autorizzazione necessaria per eseguire sono elencate nella sezione "Ruoli IAM richiesti" dell'attività.

aggiungi etichette ai set di dati

È possibile aggiungere un'etichetta a un set di dati BigQuery quando viene creato utilizzando il comando bq mk dello strumento a riga di comando bq o chiamando API datasets.insert . Attualmente, non puoi aggiungere un'etichetta a un set di dati quando viene creato utilizzando la console Google Cloud.

Questa pagina illustra come aggiungere un'etichetta a un set di dati dopo averlo creato. Per per ulteriori informazioni sull'aggiunta di un'etichetta quando crei un set di dati, consulta Creazione di un set di dati.

È possibile aggiungere un'etichetta dopo la creazione di un set di dati:

  • Utilizzo della console Google Cloud
  • Utilizzo delle istruzioni DDL SQL
  • Utilizzo del comando bq update dello strumento a riga di comando bq
  • Chiamata a datasets.patch Metodo API
  • Utilizzo delle librerie client

Quando aggiungi un'etichetta a un set di dati, questa non si propaga alle risorse all'interno del set di dati. Le etichette del set di dati non vengono ereditate da tabelle o viste. Inoltre, quando aggiungi un'etichetta a un set di dati, è inclusa nei dati di fatturazione dello spazio di archiviazione, ma non e i dati di fatturazione correlati al job.

Per ulteriori dettagli sul formato di un'etichetta, vedi Requisiti per le etichette.

Ruoli IAM richiesti

Per ottenere l'autorizzazione necessaria per aggiungere un'etichetta a un set di dati esistente, chiedi all'amministratore di concederti Ruolo IAM Editor dati BigQuery (roles/bigquery.dataEditor). Per saperne di più sulla concessione dei ruoli, consulta Gestire l'accesso.

Questo ruolo predefinito contiene bigquery.datasets.update, che è necessario per aggiungere un'etichetta a un set di dati esistente.

Potresti anche riuscire a ottenere questa autorizzazione con ruoli personalizzati e altri ruoli predefiniti.

Per ulteriori informazioni su ruoli e autorizzazioni IAM in BigQuery, vedi Autorizzazioni e ruoli predefiniti.

Aggiunta di un'etichetta a un set di dati

Per aggiungere un'etichetta a un set di dati dopo la sua creazione:

Console

  1. Nella console Google Cloud, seleziona il set di dati.

  2. Nella pagina dei dettagli del set di dati, fai clic sull'icona a forma di matita a destra del Etichette.

    Matita per etichette.

  3. Nella finestra di dialogo Modifica etichette:

    • Fai clic su Aggiungi etichetta.
    • Inserisci la chiave e il valore. Per applicare altre etichette, fai clic su Aggiungi etichetta. Ogni chiave può essere usata solo una volta per set di dati ma puoi utilizzare la stessa chiave in set di dati diversi all'interno progetto.
    • Per aggiornare un'etichetta, modifica le chiavi o i valori esistenti.
    • Per salvare le modifiche, fai clic su Aggiorna.

SQL

Utilizza la ALTER SCHEMA SET OPTIONS Istruzione DDL per impostare le etichette su un set di dati esistente. Le etichette delle impostazioni sovrascriveranno qualsiasi le etichette esistenti sul set di dati. L'esempio seguente imposta un'etichetta nella set di dati mydataset:

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

    Vai a BigQuery

  2. Nell'editor query, inserisci la seguente istruzione:

    ALTER SCHEMA mydataset
    SET OPTIONS (
      labels = [('sensitivity', 'high')]);
    

  3. Fai clic su Esegui.

Per ulteriori informazioni su come eseguire le query, vedi Eseguire una query interattiva.

bq

Per aggiungere un'etichetta a un set di dati esistente, esegui il comando bq update il flag set_label. Ripeti il flag per aggiungere più etichette.

Se il set di dati si trova in un progetto diverso da quello predefinito, aggiungi al set di dati nel seguente formato: PROJECT_ID:DATASET.

bq update --set_label KEY:VALUE PROJECT_ID:DATASET

Sostituisci quanto segue:

  • KEY:VALUE: una coppia chiave-valore per un'etichetta che che vuoi aggiungere. La chiave deve essere univoca. Le chiavi e i valori possono contenere solo lettere minuscole, caratteri numerici, trattini bassi e trattini. Tutti devono utilizzare la codifica UTF-8 e i caratteri internazionali sono consentito.
  • PROJECT_ID: il tuo ID progetto.
  • DATASET: il set di dati che stai etichettando.

Esempi:

Per aggiungere un'etichetta per monitorare i reparti, inserisci il comando bq update e specifica department come chiave di etichetta. Ad esempio, per aggiungere Etichetta department:shipping a mydataset nel progetto predefinito, inserisci:

    bq update --set_label department:shipping mydataset

Per aggiungere più etichette a un set di dati, ripeti il flag set_label e specifica una chiave univoca per ogni etichetta.Ad esempio, per aggiungere un elemento department:shipping e cost_center:logistics etichetta su mydataset nell'impostazione predefinita progetto, inserisci:

    bq update \
    --set_label department:shipping \
    --set_label cost_center:logistics \
    mydataset

API

Per aggiungere un'etichetta a un set di dati esistente, richiama il metodo datasets.patch e compila la proprietà labels per il risorsa del set di dati.

Poiché il metodo datasets.update sostituisce l'intera risorsa del set di dati, è preferibile il metodo datasets.patch.

Vai

Prima di provare questo esempio, segui le istruzioni per la configurazione di Go nel Guida rapida di BigQuery con librerie client. Per ulteriori informazioni, consulta API Go BigQuery documentazione di riferimento.

Per eseguire l'autenticazione su BigQuery, configura Credenziali predefinite dell'applicazione. Per ulteriori informazioni, vedi Configura l'autenticazione per le librerie client.

import (
	"context"
	"fmt"

	"cloud.google.com/go/bigquery"
)

// addDatasetLabel demonstrates adding label metadata to an existing dataset.
func addDatasetLabel(projectID, datasetID string) error {
	// projectID := "my-project-id"
	// datasetID := "mydataset"
	ctx := context.Background()
	client, err := bigquery.NewClient(ctx, projectID)
	if err != nil {
		return fmt.Errorf("bigquery.NewClient: %v", err)
	}
	defer client.Close()

	ds := client.Dataset(datasetID)
	meta, err := ds.Metadata(ctx)
	if err != nil {
		return err
	}

	update := bigquery.DatasetMetadataToUpdate{}
	update.SetLabel("color", "green")
	if _, err := ds.Update(ctx, update, meta.ETag); err != nil {
		return err
	}
	return nil
}

Java

Questo esempio utilizza la libreria client HTTP di Google per Java per inviare una richiesta all'API BigQuery.

Prima di provare questo esempio, segui le istruzioni per la configurazione di Java nel Guida rapida di BigQuery con librerie client. Per ulteriori informazioni, consulta API Java BigQuery documentazione di riferimento.

Per eseguire l'autenticazione su BigQuery, configura Credenziali predefinite dell'applicazione. Per ulteriori informazioni, vedi Configura l'autenticazione per le librerie client.

import com.google.cloud.bigquery.BigQuery;
import com.google.cloud.bigquery.BigQueryException;
import com.google.cloud.bigquery.BigQueryOptions;
import com.google.cloud.bigquery.Dataset;
import java.util.HashMap;
import java.util.Map;

// Sample to updates a label on dataset
public class LabelDataset {

  public static void main(String[] args) {
    // TODO(developer): Replace these variables before running the sample.
    String datasetName = "MY_DATASET_NAME";
    labelDataset(datasetName);
  }

  public static void labelDataset(String datasetName) {
    try {
      // Initialize client that will be used to send requests. This client only needs to be created
      // once, and can be reused for multiple requests.
      BigQuery bigquery = BigQueryOptions.getDefaultInstance().getService();

      // This example dataset starts with existing label { color: 'green' }
      Dataset dataset = bigquery.getDataset(datasetName);
      // Add label to dataset
      Map<String, String> labels = new HashMap<>();
      labels.put("color", "green");

      dataset.toBuilder().setLabels(labels).build().update();
      System.out.println("Label added successfully");
    } catch (BigQueryException e) {
      System.out.println("Label was not added. \n" + e.toString());
    }
  }
}

Node.js

Prima di provare questo esempio, segui le istruzioni per la configurazione di Node.js nel Guida rapida di BigQuery con librerie client. Per ulteriori informazioni, consulta API Node.js BigQuery documentazione di riferimento.

Per eseguire l'autenticazione su BigQuery, configura Credenziali predefinite dell'applicazione. Per ulteriori informazioni, vedi Configura l'autenticazione per le librerie client.

// Import the Google Cloud client library
const {BigQuery} = require('@google-cloud/bigquery');
const bigquery = new BigQuery();

async function labelDataset() {
  // Updates a label on a dataset.

  /**
   * TODO(developer): Uncomment the following lines before running the sample
   */
  // const datasetId = "my_dataset";

  // Retrieve current dataset metadata.
  const dataset = bigquery.dataset(datasetId);
  const [metadata] = await dataset.getMetadata();

  // Add label to dataset metadata
  metadata.labels = {color: 'green'};
  const [apiResponse] = await dataset.setMetadata(metadata);

  console.log(`${datasetId} labels:`);
  console.log(apiResponse.labels);
}

Python

Prima di provare questo esempio, segui le istruzioni per la configurazione di Python nel Guida rapida di BigQuery con librerie client. Per ulteriori informazioni, consulta API Python BigQuery documentazione di riferimento.

Per eseguire l'autenticazione su BigQuery, configura Credenziali predefinite dell'applicazione. Per ulteriori informazioni, vedi Configura l'autenticazione per le librerie client.


from google.cloud import bigquery

# Construct a BigQuery client object.
client = bigquery.Client()

# TODO(developer): Set dataset_id to the ID of the dataset to fetch.
# dataset_id = "your-project.your_dataset"

dataset = client.get_dataset(dataset_id)  # Make an API request.
dataset.labels = {"color": "green"}
dataset = client.update_dataset(dataset, ["labels"])  # Make an API request.

print("Labels added to {}".format(dataset_id))

Aggiungere etichette a tabelle e viste

Un'etichetta può essere aggiunta a una tabella o a una visualizzazione quando viene creata:

  • Utilizzo del comando bq mk dello strumento a riga di comando bq
  • Chiamata a tables.insert Metodo API

Questa pagina illustra come aggiungere un'etichetta a una tabella o a una visualizzazione esistente. Per ulteriori informazioni informazioni sull'aggiunta di un'etichetta quando crei una tabella o una vista, consulta Creazione di una tabella o Creazione di una vista.

È possibile aggiungere un'etichetta dopo aver creato una tabella o una visualizzazione mediante:

  • Utilizzo della console Google Cloud
  • Utilizzo del comando bq update dello strumento a riga di comando bq
  • Chiamata a tables.patch Metodo API
  • Utilizzo delle librerie client

Poiché le visualizzazioni vengono trattate come risorse di una tabella, utilizzi l'tables.patch per modificare sia le viste che le tabelle.

Ruoli IAM richiesti

Per ottenere le autorizzazioni necessarie per aggiungere un'etichetta a una tabella o una vista esistente, chiedi all'amministratore di concederti Ruolo IAM Editor dati BigQuery (roles/bigquery.dataEditor). Per saperne di più sulla concessione dei ruoli, consulta Gestire l'accesso.

Questo ruolo predefinito contiene le autorizzazioni necessarie per aggiungere un'etichetta a una tabella o una vista esistente. Per vedere le autorizzazioni esatte obbligatorie, espandi la sezione Autorizzazioni obbligatorie:

Autorizzazioni obbligatorie

Per aggiungere un'etichetta a una tabella o una vista esistente sono necessarie le seguenti autorizzazioni:

  • bigquery.tables.update
  • bigquery.tables.get

Potresti anche riuscire a ottenere queste autorizzazioni con ruoli personalizzati e altri ruoli predefiniti.

Per ulteriori informazioni su ruoli e autorizzazioni IAM in BigQuery, vedi Autorizzazioni e ruoli predefiniti.

Aggiungere un'etichetta a una tabella o una visualizzazione

Per aggiungere un'etichetta a una tabella o una visualizzazione esistente:

Console

  1. Nella console Google Cloud, seleziona la tabella o visualizza.

  2. Fai clic sulla scheda Dettagli.

    Dettagli tabella.

  3. Fai clic sull'icona a forma di matita a destra di Etichette.

    Matita per etichette.

  4. Nella finestra di dialogo Modifica etichette:

    • Fai clic su Aggiungi etichetta.
    • Inserisci la chiave e il valore per aggiungere un'etichetta. Per applicare altre etichette, fai clic su Aggiungi etichetta. Ogni chiave può essere usata solo una volta per set di dati ma puoi utilizzare la stessa chiave in set di dati diversi nello stesso progetto.
    • Modifica le chiavi o i valori esistenti per aggiornare un'etichetta.
    • Fai clic su Update (Aggiorna) per salvare le modifiche.

SQL

Utilizza la ALTER TABLE SET OPTIONS Istruzione DDL per impostare le etichette su una tabella esistente, oppure Istruzione DDL ALTER VIEW SET OPTIONS per impostare le etichette su una vista esistente. Le etichette delle impostazioni sovrascriveranno qualsiasi le etichette esistenti nella tabella o nella visualizzazione. L'esempio seguente imposta due etichette nella tabella mytable:

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

    Vai a BigQuery

  2. Nell'editor query, inserisci la seguente istruzione:

    ALTER TABLE mydataset.mytable
    SET OPTIONS (
      labels = [('department', 'shipping'), ('cost_center', 'logistics')]);
    

  3. Fai clic su Esegui.

Per ulteriori informazioni su come eseguire le query, vedi Eseguire una query interattiva.

bq

Per aggiungere un'etichetta a una tabella o una vista esistente, esegui il comando bq update con il flag set_label. Per aggiungere più etichette, ripeti il flag.

Se la tabella o la visualizzazione si trova in un progetto diverso da quello predefinito, aggiungi l'ID progetto al set di dati nel seguente formato: project_id:dataset.

bq update \
--set_label KEY:VALUE \
PROJECT_ID:DATASET.TABLE_OR_VIEW

Sostituisci quanto segue:

  • KEY:VALUE: una coppia chiave-valore per un'etichetta che che vuoi aggiungere. La chiave deve essere univoca. Le chiavi e i valori possono contenere solo lettere minuscole, caratteri numerici, trattini bassi e trattini. Tutti devono utilizzare la codifica UTF-8 e i caratteri internazionali sono consentito.
  • PROJECT_ID: il tuo ID progetto.
  • DATASET: il set di dati che contiene la tabella o vista che stai etichettando.
  • TABLE_OR_VIEW: il nome della tabella o della visualizzazione che stai etichettando.

Esempi:

Per aggiungere un'etichetta di tabella che tenga traccia dei reparti, inserisci il comando bq update e specificare department come chiave di etichetta. Ad esempio, per aggiungere Etichetta department:shipping a mytable nel progetto predefinito, inserisci:

    bq update --set_label department:shipping mydataset.mytable

Per aggiungere un'etichetta di visualizzazione che tenga traccia dei reparti, inserisci il comando bq update e specificare department come chiave di etichetta. Ad esempio, per aggiungere Etichetta department:shipping a myview nel progetto predefinito, inserisci:

    bq update --set_label department:shipping mydataset.myview

Per aggiungere più etichette a una tabella o una visualizzazione, ripeti il flag set_label e specificare una chiave univoca per ogni etichetta. Ad esempio, per aggiungere Etichetta department:shipping e cost_center:logistics etichetta in mytable nel progetto predefinito, inserisci:

    bq update \
    --set_label department:shipping \
    --set_label cost_center:logistics \
    mydataset.mytable

API

Per aggiungere un'etichetta a una tabella o una visualizzazione esistente, chiama il metodo tables.patch e compila la proprietà labels per il risorsa della tabella.

Poiché le visualizzazioni vengono trattate come risorse di una tabella, utilizzi l'tables.patch per modificare sia le viste che le tabelle.

Poiché il metodo tables.update sostituisce l'intera risorsa del set di dati, il valore È preferito il metodo tables.patch.

Vai

Prima di provare questo esempio, segui le istruzioni per la configurazione di Go nel Guida rapida di BigQuery con librerie client. Per ulteriori informazioni, consulta API Go BigQuery documentazione di riferimento.

Per eseguire l'autenticazione su BigQuery, configura Credenziali predefinite dell'applicazione. Per ulteriori informazioni, vedi Configura l'autenticazione per le librerie client.

import (
	"context"
	"fmt"

	"cloud.google.com/go/bigquery"
)

// addTableLabel demonstrates adding Label metadata to a BigQuery table.
func addTableLabel(projectID, datasetID, tableID string) error {
	// projectID := "my-project-id"
	// datasetID := "mydataset"
	// tableID := "mytable"
	ctx := context.Background()
	client, err := bigquery.NewClient(ctx, projectID)
	if err != nil {
		return fmt.Errorf("bigquery.NewClient: %v", err)
	}
	defer client.Close()

	tbl := client.Dataset(datasetID).Table(tableID)
	meta, err := tbl.Metadata(ctx)
	if err != nil {
		return err
	}

	update := bigquery.TableMetadataToUpdate{}
	update.SetLabel("color", "green")
	if _, err := tbl.Update(ctx, update, meta.ETag); err != nil {
		return err
	}
	return nil
}

Java

Questo esempio utilizza la libreria client HTTP di Google per Java per inviare una richiesta all'API BigQuery.

Prima di provare questo esempio, segui le istruzioni per la configurazione di Java nel Guida rapida di BigQuery con librerie client. Per ulteriori informazioni, consulta API Java BigQuery documentazione di riferimento.

Per eseguire l'autenticazione su BigQuery, configura Credenziali predefinite dell'applicazione. Per ulteriori informazioni, vedi Configura l'autenticazione per le librerie client.

import com.google.cloud.bigquery.BigQuery;
import com.google.cloud.bigquery.BigQueryException;
import com.google.cloud.bigquery.BigQueryOptions;
import com.google.cloud.bigquery.Table;
import com.google.cloud.bigquery.TableId;
import java.util.HashMap;
import java.util.Map;

// Sample to adds a label to an existing table
public class LabelTable {

  public static void main(String[] args) {
    // TODO(developer): Replace these variables before running the sample.
    String datasetName = "MY_DATASET_NAME";
    String tableName = "MY_TABLE_NAME";
    labelTable(datasetName, tableName);
  }

  public static void labelTable(String datasetName, String tableName) {
    try {
      // Initialize client that will be used to send requests. This client only needs to be created
      // once, and can be reused for multiple requests.
      BigQuery bigquery = BigQueryOptions.getDefaultInstance().getService();

      // This example table starts with existing label { color: 'green' }
      Table table = bigquery.getTable(TableId.of(datasetName, tableName));
      // Add label to table
      Map<String, String> labels = new HashMap<>();
      labels.put("color", "green");

      table.toBuilder().setLabels(labels).build().update();
      System.out.println("Label added successfully");
    } catch (BigQueryException e) {
      System.out.println("Label was not added. \n" + e.toString());
    }
  }
}

Node.js

Prima di provare questo esempio, segui le istruzioni per la configurazione di Node.js nel Guida rapida di BigQuery con librerie client. Per ulteriori informazioni, consulta API Node.js BigQuery documentazione di riferimento.

Per eseguire l'autenticazione su BigQuery, configura Credenziali predefinite dell'applicazione. Per ulteriori informazioni, vedi Configura l'autenticazione per le librerie client.

// Import the Google Cloud client library
const {BigQuery} = require('@google-cloud/bigquery');
const bigquery = new BigQuery();

async function labelTable() {
  // Adds a label to an existing table.

  /**
   * TODO(developer): Uncomment the following lines before running the sample.
   */
  // const datasetId = 'my_dataset';
  // const tableId = 'my_table';

  const dataset = bigquery.dataset(datasetId);
  const [table] = await dataset.table(tableId).get();

  // Retrieve current table metadata
  const [metadata] = await table.getMetadata();

  // Add label to table metadata
  metadata.labels = {color: 'green'};
  const [apiResponse] = await table.setMetadata(metadata);

  console.log(`${tableId} labels:`);
  console.log(apiResponse.labels);
}

Python

Prima di provare questo esempio, segui le istruzioni per la configurazione di Python nel Guida rapida di BigQuery con librerie client. Per ulteriori informazioni, consulta API Python BigQuery documentazione di riferimento.

Per eseguire l'autenticazione su BigQuery, configura Credenziali predefinite dell'applicazione. Per ulteriori informazioni, vedi Configura l'autenticazione per le librerie client.

from google.cloud import bigquery

client = bigquery.Client()

# TODO(dev): Change table_id to the full name of the table you want to create.
table_id = "your-project.your_dataset.your_table_name"

table = client.get_table(table_id)  # API request

labels = {"color": "green"}
table.labels = labels

table = client.update_table(table, ["labels"])  # API request

print(f"Added {table.labels} to {table_id}.")

Aggiunta di etichette ai job

È possibile aggiungere etichette ai job di query tramite la riga di comando utilizzando flag --label dello strumento a riga di comando bq. Lo strumento bq supporta l'aggiunta di solo per i job di query.

Puoi anche aggiungere un'etichetta a un job inviato tramite l'API specificando la proprietà labels nella configurazione del job quando chiami la jobs.insert. L'API può essere utilizzato per aggiungere etichette a qualsiasi tipo di job.

Non puoi aggiungere etichette alle etichette né aggiornarle per quelle in attesa, in esecuzione o completate di lavoro.

Quando aggiungi un'etichetta a un job, questa viene inclusa nei dati di fatturazione.

Ruoli IAM richiesti

Per ottenere l'autorizzazione necessaria per aggiungere un'etichetta a un job, chiedi all'amministratore di concederti Ruolo IAM Utente BigQuery (roles/bigquery.user). Per saperne di più sulla concessione dei ruoli, consulta Gestire l'accesso.

Questo ruolo predefinito contiene bigquery.jobs.create, che è necessaria per aggiungere un'etichetta a un job.

Potresti anche riuscire a ottenere questa autorizzazione con ruoli personalizzati e altri ruoli predefiniti.

Per ulteriori informazioni su ruoli e autorizzazioni IAM in BigQuery, vedi Autorizzazioni e ruoli predefiniti.

Aggiunta di un'etichetta a un job

Per aggiungere un'etichetta a un job:

bq

Per aggiungere un'etichetta a un job di query, esegui il comando bq query con il flag --label. Per aggiungere più etichette, ripeti il flag. La Il flag --nouse_legacy_sql indica che la query è in formato GoogleSQL a riga di comando.

bq query --label KEY:VALUE --nouse_legacy_sql 'QUERY'

Sostituisci quanto segue:

  • KEY:VALUE: una coppia chiave-valore per un'etichetta che da aggiungere al job di query. La chiave deve essere univoca. Chiavi e valori possono contenere solo lettere minuscole, caratteri numerici, trattini bassi e trattini bassi. Tutti i caratteri devono utilizzare la codifica UTF-8 e i caratteri internazionali sono consentiti. Per aggiungere più etichette a un job di query, ripeti il comando --label e specifica una chiave univoca per ogni etichetta.
  • QUERY: una query GoogleSQL valida.

Esempi:

Per aggiungere un'etichetta a un job di query, inserisci:

    bq query \
    --label department:shipping \
    --nouse_legacy_sql \
    'SELECT
       column1, column2
     FROM
       `mydataset.mytable`'

Per aggiungere più etichette a un job di query, ripeti il flag --label e specificare una chiave univoca per ogni etichetta. Ad esempio, per aggiungere Etichetta department:shipping e cost_center:logistics etichetta a una query job, inserisci:

    bq query \
    --label department:shipping \
    --label cost_center:logistics \
    --nouse_legacy_sql \
    'SELECT
       column1, column2
     FROM
       `mydataset.mytable`'

API

Per aggiungere un'etichetta a un job, richiama il metodo jobs.insert e compila la proprietà labels per il configurazione del job. Puoi utilizzare l'API per aggiungere etichette a qualsiasi tipo di job.

Associare i job di una sessione a un'etichetta

Se esegui query in una sessione, puoi assegnare un'etichetta tutti i job di query futuri nella sessione utilizzando BigQuery a più istruzioni.

SQL

Imposta la @@query_label di sistema nella sessione eseguendo questa query:

  SET @@query_label = "KEY:VALUE";
  

  • KEY:VALUE: una coppia chiave-valore che l'etichetta deve assegnare a tutte le occorrenze future query nella sessione. La chiave deve essere univoca. Le chiavi e i valori possono contenere solo lettere minuscole, caratteri numerici, trattini bassi e trattini. Tutti i caratteri devono utilizzare la codifica UTF-8 della codifica e caratteri internazionali.

Esempio:

  SET @@query_label = "cost_center:logistics";
  

API

Per aggiungere un'etichetta a un job di query in una sessione quando esegui una query utilizzando una chiamata API, chiama jobs.insert e compilano la proprietà query_label per il connectionProperties configurazione del job.

Dopo aver associato un'etichetta di query a una sessione ed eseguito query all'interno durante la sessione, puoi raccogliere gli audit log per le query con quell'etichetta. Per ulteriori informazioni, consulta Informazioni sugli audit log per BigQuery.

Aggiunta di un'etichetta senza un valore

Un'etichetta con una chiave con un valore vuoto a volte viene chiamata tag. Questo non deve essere confuso con una risorsa di tag. Per ulteriori informazioni informazioni, consulta etichette e tag. Puoi creare una nuova etichetta senza valore o puoi rimuovere un valore da un chiave di etichetta esistente.

Le etichette senza valori possono essere utili nelle situazioni in cui stai etichettando un ma non hai bisogno del formato chiave-valore. Ad esempio, se una tabella contiene dati di test utilizzati da più gruppi, come il supporto o sviluppo, puoi aggiungere un'etichetta test_data alla tabella per identificarla.

Per aggiungere un'etichetta senza un valore:

Console

  1. Nella console Google Cloud, seleziona la risorsa appropriata (una un set di dati, una tabella o una vista).

  2. Per i set di dati, viene aperta automaticamente la pagina dei dettagli del set di dati. Per tabelle e visualizzazioni, fai clic su Dettagli per aprire la pagina dei dettagli.

    Dettagli tabella.

  3. Nella pagina dei dettagli, fai clic sull'icona a forma di matita a destra di Etichette.

    Matita per etichette.

  4. Nella finestra di dialogo Modifica etichette:

    • Fai clic su Aggiungi etichetta.
    • Inserisci una nuova chiave e lascia vuoto il valore. Per applicare altre etichette, fai clic su Aggiungi etichetta e ripeti.
    • Per salvare le modifiche, fai clic su Aggiorna.

SQL

Per aggiungere un'etichetta senza un valore, utilizza il metodo ALTER TABLE SET OPTIONS Istruzione DDL:

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

    Vai a BigQuery

  2. Nell'editor query, inserisci la seguente istruzione:

    ALTER TABLE mydataset.mytable
    SET OPTIONS (
      labels=[("key1", ""), ("key2", "")]);
    

  3. Fai clic su Esegui.

Per ulteriori informazioni su come eseguire le query, vedi Eseguire una query interattiva.

bq

Per aggiungere un'etichetta senza un valore a una risorsa esistente, utilizza il metodo il comando bq update con Flag set_label. Specifica la chiave, seguita da due punti, ma lascia il valore non specificato.

bq update --set_label KEY: RESOURCE_ID

Sostituisci quanto segue:

  • KEY:: la chiave di etichetta che vuoi utilizzare.
  • RESOURCE_ID: nome valido per un set di dati, una tabella o una vista. Se la risorsa si trova in un progetto diverso da quello predefinito, aggiungi la risorsa ID progetto nel seguente formato: PROJECT_ID:DATASET.

Esempi:

Inserisci questo comando per creare un'etichetta test_data per mydataset.mytable. mydataset è nel tuo progetto predefinito.

bq update --set_label test_data: mydataset

API

Chiama il datasets.patch o tables.patch e aggiungere etichette con il valore impostato sulla stringa vuota ("") nel risorsa set di dati o la risorsa tabella. Puoi rimuovere i valori dalle etichette esistenti sostituendo i valori con la stringa vuota.

Poiché le visualizzazioni vengono trattate come risorse di una tabella, utilizzi l'tables.patch per modificare sia le viste che le tabelle. Inoltre, poiché tables.update sostituisce l'intera risorsa del set di dati, il metodo tables.patch è preferito.

Passaggi successivi