Visualizzazione VIEWS

La vista INFORMATION_SCHEMA.VIEWS contiene i metadati sulle visualizzazioni.

Autorizzazioni obbligatorie

Per ottenere i metadati della visualizzazione, devi disporre delle seguenti autorizzazioni Identity and Access Management (IAM):

  • bigquery.tables.get
  • bigquery.tables.list

Ciascuno dei seguenti ruoli IAM predefiniti include le autorizzazioni necessarie per visualizzare i metadati:

  • roles/bigquery.admin
  • roles/bigquery.dataEditor
  • roles/bigquery.metadataViewer
  • roles/bigquery.dataViewer

Per ulteriori informazioni sulle autorizzazioni BigQuery, consulta Controllo dell'accesso con IAM.

Schema

Quando esegui una query sulla visualizzazione INFORMATION_SCHEMA.VIEWS, i risultati della query contengono una riga per ogni visualizzazione in un set di dati.

La vista INFORMATION_SCHEMA.VIEWS ha lo schema seguente:

Nome colonna Tipo di dati Valore
TABLE_CATALOG STRING Il nome del progetto contenente il set di dati
TABLE_SCHEMA STRING Il nome del set di dati che contiene la vista, chiamato anche set di dati id
TABLE_NAME STRING Il nome della visualizzazione, chiamato anche tabella id
VIEW_DEFINITION STRING La query SQL che definisce la vista
CHECK_OPTION STRING Il valore restituito è sempre NULL
USE_STANDARD_SQL STRING YES se la vista è stata creata utilizzando una query GoogleSQL; NO se useLegacySql è impostato su true

Ambito e sintassi

Le query su questa vista devono includere un set di dati o un qualificatore di regione. Per le query con un qualificatore del set di dati, devi disporre delle autorizzazioni per il set di dati. Per le query con un qualificatore regione, devi disporre delle autorizzazioni per il progetto. Per ulteriori informazioni, consulta la sezione Sintassi. La tabella seguente illustra gli ambiti della regione e delle risorse per questa visualizzazione:

Nome vista Ambito risorsa Ambito regione
[PROJECT_ID.]`region-REGION`.INFORMATION_SCHEMA.VIEWS Livello progetto REGION
[PROJECT_ID.]DATASET_ID.INFORMATION_SCHEMA.VIEWS A livello di set di dati Posizione del set di dati
Sostituisci quanto segue:

  • Facoltativo: PROJECT_ID: l'ID del tuo progetto Google Cloud. Se non viene specificato, viene utilizzato il progetto predefinito.

    Ad esempio:

    -- Returns metadata for views in a single dataset.
    SELECT * FROM myDataset.INFORMATION_SCHEMA.VIEWS;
    
    -- Returns metadata for all views in a region.
    SELECT * FROM region-us.INFORMATION_SCHEMA.VIEWS;
    

    Esempi

    Esempio 1:

    L'esempio seguente recupera tutte le colonne dalla vista INFORMATION_SCHEMA.VIEWS tranne check_option, che è riservata per un uso futuro. I metadati retitrati si riferiscono a tutte le visualizzazioni in mydataset nel progetto predefinito myproject.

    Per eseguire la query su un progetto diverso da quello predefinito, aggiungi l'ID progetto al set di dati nel seguente formato: `project_id`.dataset.INFORMATION_SCHEMA.view; ad esempio, `myproject`.mydataset.INFORMATION_SCHEMA.VIEWS.

    SELECT
      * EXCEPT (check_option)
    FROM
      mydataset.INFORMATION_SCHEMA.VIEWS;

    Il risultato è simile al seguente:

      +----------------+---------------+---------------+---------------------------------------------------------------------+------------------+
      | table_catalog  | table_schema  |  table_name   |                        view_definition                              | use_standard_sql |
      +----------------+---------------+---------------+---------------------------------------------------------------------+------------------+
      | myproject      | mydataset     | myview        | SELECT column1, column2 FROM [myproject:mydataset.mytable] LIMIT 10 | NO               |
      +----------------+---------------+---------------+---------------------------------------------------------------------+------------------+
      

    Tieni presente che i risultati mostrano che questa visualizzazione è stata creata utilizzando una query SQL precedente.

    Esempio 2:

    Il seguente esempio recupera la query SQL e la sintassi delle query utilizzate per definire myview in mydataset nel progetto predefinito myproject.

    Per eseguire la query su un progetto diverso da quello predefinito, aggiungi l'ID progetto al set di dati nel seguente formato: `project_id`.dataset.INFORMATION_SCHEMA.view; ad esempio, `myproject`.mydataset.INFORMATION_SCHEMA.VIEWS.

    SELECT
      table_name, view_definition, use_standard_sql
    FROM
      mydataset.INFORMATION_SCHEMA.VIEWS
    WHERE
      table_name = 'myview';

    Il risultato è simile al seguente:

      +---------------+---------------------------------------------------------------+------------------+
      |  table_name   |                        view_definition                        | use_standard_sql |
      +---------------+---------------------------------------------------------------+------------------+
      | myview        | SELECT column1, column2, column3 FROM mydataset.mytable       | YES              |
      +---------------+---------------------------------------------------------------+------------------+
      

    Tieni presente che i risultati mostrano che questa visualizzazione è stata creata utilizzando una query GoogleSQL.