Condividi tramite


Google BigQuery

Riepilogo

Articolo Descrizione
Stato di rilascio Disponibilità generale
Prodotti Power BI (modelli semantici)
Power BI (flussi di dati)
Infrastruttura (Dataflow Gen2)
Power Apps (flussi di dati)
Customer Insights (flussi di dati)
Tipi di autenticazione supportati Organizational account
Account di servizio

Nota

Alcune funzionalità possono essere presenti in un prodotto, ma non altre a causa di pianificazioni di distribuzione e funzionalità specifiche dell'host.

Nota

A partire da luglio 2021, Google ha sospeso il supporto per gli accessi agli account Google da framework browser incorporati. A causa di questa modifica, è necessario aggiornare la versione di Power BI Desktop a giugno 2021 o versione successiva per supportare l'accesso a Google.

Prerequisiti

È necessario un account Google o un account del servizio Google per accedere a Google BigQuery.

Capacità supportate

  • Importa
  • DirectQuery (modelli semantici di Power BI)

Connettersi ai dati di Google BigQuery da Power Query Desktop

Per connettersi a Google BigQuery da Power Query Desktop, seguire questa procedura:

  1. Selezionare Google BigQuery nell'esperienza di recupero dei dati. L'esperienza di recupero dei dati in Power Query Desktop varia a seconda delle app. Per altre informazioni sull'esperienza dati di Power Query Desktop per l'app, vedere Dove ottenere i dati.

  2. Per usare le opzioni avanzate, selezionare Opzioni avanzate. In caso contrario, selezionare OK per continuare. Altre informazioni: Connettersi con le opzioni avanzate

    Immagine che mostra la finestra di dialogo iniziale con la selezione delle opzioni avanzate.

  3. Il connettore Google BigQuery supporta la connessione tramite un account aziendale o un account del servizio. In questo esempio usare l'account aziendale per accedere. Selezionare Accedi per continuare.

    Accedere a Google BigQuery.

    È anche possibile accedere usando un account del servizio Google. In questo caso, selezionare Account di accesso al servizio e immettere il messaggio di posta elettronica dell'account del servizio e il contenuto del file di chiave JSON dell'account del servizio. Selezionare Connetti.

  4. Viene visualizzata una finestra di dialogo Accedi con Google . Selezionare l'account Google e approvare la connessione a Power BI Desktop.

    Accedere a Google.

  5. Dopo l'accesso, selezionare Connetti per continuare.

    Connettersi a Google BigQuery Data.

  6. Dopo la connessione, viene visualizzata una finestra Strumento di navigazione che visualizza i dati disponibili nel server. Selezionare i dati nello strumento di navigazione. Selezionare quindi Trasforma dati per trasformare i dati in Power Query o Carica per caricare i dati in Power BI Desktop.

    Immagine dello strumento di navigazione di Power Query che carica i dati Di Google BigQuery nell'app desktop.

Connettersi ai dati di Google BigQuery da Power Query Online

Per connettersi a Google BigQuery da Power Query Online, seguire questa procedura:

  1. Selezionare l'opzione Google BigQuery nell'esperienza di recupero dei dati. Diverse app hanno diversi modi per ottenere l'esperienza dei dati in Power Query Online. Per altre informazioni su come accedere a Power Query Online, vedere Dove ottenere i dati dall'app.

    Screenshot della finestra di dialogo Recupera dati con l'accento sul connettore Google BigQuery.

  2. Nella finestra di dialogo Database BigQuery di Google potrebbe essere necessario creare una nuova connessione o selezionare una connessione esistente. Se si usano dati locali, selezionare un gateway dati locale. Quindi seleziona Accedi.

    Immagine della finestra di dialogo di accesso.

  3. Viene visualizzata una finestra di dialogo Accedi con Google . Selezionare l'account Google e approvare la connessione.

    Nota

    Anche se la finestra di dialogo di accesso indica che si continuerà a usare Power BI Desktop dopo aver eseguito l'accesso, si verrà invece inviati all'app online.

    Immagine della finestra di dialogo di accesso di Google.

  4. Per usare le opzioni avanzate, selezionare Opzioni avanzate. Altre informazioni: Connettersi con le opzioni avanzate

  5. Dopo l'accesso, selezionare Avanti per continuare.

    Immagine dell'utente che ha eseguito l'accesso.

  6. Dopo la connessione, viene visualizzata una finestra Strumento di navigazione che visualizza i dati disponibili nel server. Selezionare i dati nello strumento di navigazione. Selezionare quindi Avanti per trasformare i dati in Power Query.

    Immagine dello strumento di navigazione di Power Query che carica i dati di Google BigQuery nell'app online.

Connettersi tramite opzioni avanzate

Power Query Desktop e Power Query Online offrono un set di opzioni avanzate che è possibile aggiungere alla query, se necessario.

Visualizzazione delle opzioni avanzate disponibili in Power Query Desktop.

La tabella seguente elenca tutte le opzioni avanzate che è possibile impostare in Power Query Desktop e Power Query Online.

Opzione avanzata Descrizione
ID progetto di fatturazione Progetto in cui Power Query eseguirà query. Le autorizzazioni e la fatturazione sono associate a questo progetto. Se non viene fornito alcun ID progetto di fatturazione, per impostazione predefinita verrà usato il primo progetto disponibile restituito dalle API Google.
Usare l'API di archiviazione Flag che abilita l'uso dell'API di archiviazione di Google BigQuery. Questa opzione è true per impostazione predefinita. Questa opzione può essere impostata su false per non usare l'API di archiviazione e usare invece le API REST.
Durata del timeout della connessione Impostazione di connessione standard (in secondi) che controlla per quanto tempo Power Query attende il completamento di una connessione. È possibile modificare questo valore se la connessione non viene completata prima di 15 secondi (valore predefinito).
Durata del timeout del comando Per quanto tempo Power Query attende il completamento e la restituzione dei risultati di una query. Il valore predefinito dipende dal valore predefinito del driver. È possibile immettere un altro valore in minuti per mantenere la connessione aperta più a lungo.
ID progetto Progetto su cui si desidera eseguire query native. Questa opzione è disponibile solo in Power Query Desktop.
SQL statement Per informazioni, vedere Importare dati da un database usando una query di database nativa. In questa versione della funzionalità di query del database nativo è necessario usare nomi di tabella completi nel formato Database.Schema.Table, ad esempio SELECT * FROM DEMO_DB.PUBLIC.DEMO_TABLE. Questa opzione è disponibile solo in Power Query Desktop.

Dopo aver selezionato le opzioni avanzate necessarie, selezionare OK in Power Query Desktop o Avanti in Power Query Online per connettersi ai dati di Google BigQuery.

Limitazioni e considerazioni

Questa sezione descrive eventuali limitazioni o considerazioni del connettore Google BigQuery.

Connessione a Google BigQuery in Power BI Desktop

Esistono alcuni limiti e considerazioni da tenere presenti quando si usa il connettore Google BigQuery con Power BI.

Disponibilità del connettore

Il connettore Google BigQuery è disponibile in Power BI Desktop e nel servizio Power BI. Nel servizio Power BI è possibile accedere al connettore usando la connessione da cloud a cloud da Power BI a Google BigQuery.

Errore "Accesso negato"

Quando si tenta di connettersi a Google BigQuery da Power BI Desktop, è possibile che venga visualizzato il messaggio di errore seguente:

Datasource.Error: ODBC: ERROR [HY000][Microsoft][BigQuery] (100) Error interacting with REST API: Access Denied: Project <project name>: The user <user name> bigquery.jobs.create permissions in project <project name>.

In questo caso, potrebbe essere necessario immettere un ID progetto di fatturazione nell'opzione avanzata Progetto di fatturazione nelle impostazioni di connessione di Power Query.

Inoltre, se si crea anche un report in servizio Power BI usando un gateway, è comunque possibile che venga visualizzato questo errore. In questo caso, è necessario includere manualmente l'ID progetto di fatturazione nel codice M per la connessione usando l'editor di Power Query o la barra della formula di Power Query. Ad esempio:

Source = GoogleBigQuery.Database([BillingProject="Include-Billing-Project-Id-Here"])

Campi annidati

Per ottimizzare le considerazioni sulle prestazioni, Google BigQuery funziona bene con set di dati di grandi dimensioni quando denormalizzati, appiattiti e annidati.

Il connettore Google BigQuery supporta i campi annidati, che vengono caricati come colonne di testo in formato JSON.

Supporto dei campi annidati di Google BigQuery.

Gli utenti devono selezionare Trasforma dati e quindi usare le funzionalità di analisi JSON nel editor di Power Query per estrarre i dati.

  1. Nella scheda Trasforma della barra multifunzione, la categoria Colonna di testo selezionare Analizza e quindi JSON.
  2. Estrarre i campi del record JSON usando l'opzione Espandi colonna .

Configurazione di un account del servizio Google

Per altre informazioni sulla configurazione o sull'uso degli account del servizio Google, vedere Creazione e gestione delle chiavi dell'account del servizio nella documentazione di Google.

Autenticazione tramite un account del servizio Google

Quando si esegue l'autenticazione tramite un account del servizio Google in Power BI Desktop, è disponibile un formato di credenziale specifico richiesto dal connettore.

  • Indirizzo di posta elettronica dell'account del servizio: deve essere in formato di posta elettronica
  • Contenuto del file di chiave JSON dell'account del servizio: una volta scaricata questa chiave JSON, tutte le nuove righe devono essere rimosse dal file in modo che il contenuto si trovi in una sola riga. Quando il file JSON è in tale formato, il contenuto può essere incollato in questo campo.

Quando si esegue l'autenticazione tramite un account del servizio Google in servizio Power BI o Power Query Online, gli utenti devono usare l'autenticazione di base. Il campo Nome utente viene mappato al campo Indirizzo di posta elettronica dell'account del servizio e il campo Password viene mappato al campo Contenuto del file di chiave JSON dell'account del servizio. I requisiti di formato per ogni credenziale rimangono invariati sia in Power BI Desktop, servizio Power BI che in Power Query Online.

Impossibile eseguire l'autenticazione con l'API Google BigQuery Storage

Il connettore Google BigQuery usa l'API Google BigQuery Storage per impostazione predefinita. Questa funzionalità è controllata dall'opzione avanzata denominata UseStorageApi. Se si usano autorizzazioni granulari, potrebbero verificarsi problemi con questa funzionalità. In questo scenario potrebbe essere visualizzato il messaggio di errore seguente o non è possibile ottenere dati dalla query:

ERROR [HY000] [Microsoft][BigQuery] (131) Unable to authenticate with Google BigQuery Storage API. Check your account permissions

È possibile risolvere questo problema modificando correttamente le autorizzazioni utente per l'API di archiviazione BigQuery. Queste autorizzazioni dell'API di archiviazione sono necessarie per accedere correttamente ai dati con l'API BigQueryStorage:

  • bigquery.readsessions.create: crea una nuova sessione di lettura tramite l'API di archiviazione BigQuery.
  • bigquery.readsessions.getData: legge i dati da una sessione di lettura tramite l'API di archiviazione BigQuery.
  • bigquery.readsessions.update: aggiorna una sessione di lettura tramite l'API di archiviazione BigQuery.

Queste autorizzazioni vengono in genere fornite nel BigQuery.User ruolo. Altre informazioni, Ruoli e autorizzazioni predefiniti di Google BigQuery

Se i passaggi precedenti non risolvono il problema, è possibile disabilitare l'API di archiviazione BigQuery.

Impossibile usare i dati di tipo DateTime in modalità Direct Query

Esiste un problema noto per cui il tipo DateTime non è supportato tramite Direct Query. Se si seleziona una colonna con tipo DateTime, viene generato un errore "Query non valida" o un errore visivo.

Limitazioni relative alla colonna di query con lo stesso nome della tabella

Quando si esegue una query su una colonna con lo stesso nome della tabella, BigQuery interpreta la colonna come che struct include tutte le colonne della tabella anziché la colonna specificata. Ad esempio, restituisce SELECT debug FROM dataset.debug un oggetto struct con tutte le colonne della tabella di debug, anziché la colonna di debug specificata. Questo comportamento non è intuitivo e viene esaminata una correzione. Sono disponibili tre soluzioni alternative:

  • Soluzione alternativa 1: Eseguire il wrapping della tabella con una vista che non è in conflitto con il nome della colonna:CREATE VIEW dataset.new_view AS SELECT * FROM dataset.debug
  • Soluzione alternativa 2: Rinominare la colonna per evitare conflitti con il nome della tabella:ALTER TABLE dataset.debug RENAME COLUMN debug to new_debug
  • Soluzione alternativa 3: Modificare la query SELECT per usare table.column per fare riferimento alla colonna dei conflitti:SELECT debug.debug FROM dataset.debug

Le visualizzazioni materializzate non sono supportate nello strumento di spostamento di Power BI Desktop

Un problema noto è che il connettore Google BigQuery attualmente non supporta le visualizzazioni materializzate nello strumento di spostamento di Power BI Desktop.

  • Soluzione alternativa: usare istruzioni SQL di query native per recuperare le viste materializzate da Google BigQuery.

Errore HTTP 403: quota superata (quota superata: l'utente ha superato la quota per le richieste di project.lists simultanee)

  • La quota viene superata nell'utilizzo dell'account cliente delle chiamate API project.lists a Google. Quando più report vengono aggiornati contemporaneamente, potrebbe generare un errore in query o report diversi. Per evitare l'errore, pianificare gli aggiornamenti del report a intervalli sfalsati.
  • Aggiornare la query per includere un ID progetto di fatturazione - GoogleBigQuery.Database([BillingProject="Include-Billing-Project-Id-Here"]).
  • Le chiamate a GoogleBigQuery.Database devono trovarsi nella stessa query dello schema e della selezione della tabella per evitare l'errore.