Utilizzare il driver ODBC per BigQuery
Il driver Open Database Connectivity (ODBC) per BigQuery connette le tue applicazioni non Java a BigQuery, consentendoti di utilizzare le funzionalità di BigQuery con gli strumenti e l'infrastruttura che preferisci. Per connettere le applicazioni Java a BigQuery, utilizza il driver JDBC per BigQuery.
Il driver ODBC per BigQuery è disponibile con la licenza Apache 2.0.
Prima di iniziare
Assicurati di avere familiarità con i driver ODBC e i gestori dei driver.
Assicurati che il tuo sistema operativo soddisfi i seguenti requisiti:
Sistema operativo Architetture supportate Versione minima e dipendenze Windows 32 bit (x86), 64 bit (x64) Versione: Windows 10, Windows Server 2016 o versioni successive
Dipendenza: Microsoft Visual C++ Redistributable per Visual Studio 2019 o 2022macOS 64 bit (x86_64), ARM64 (Apple Silicon) Versione: macOS 12 (Monterey) o versioni successive
Dipendenza: un gestore di driver ODBC (ad esempio unixODBC). Assicurati di aggiungere la directory di installazione aDYLD_LIBRARY_PATH.Linux 64 bit (x86_64) Versione: qualsiasi distribuzione con glibc 2.27 o versioni successive (ad esempio Ubuntu 20.04 LTS+, Debian 11+)
Dipendenza: un gestore di driver ODBC (ad esempio unixODBC). Assicurati di aggiungere la directory di installazione aLD_LIBRARY_PATH.Autenticati in BigQuery e prendi nota delle seguenti informazioni, che verranno utilizzate in un secondo momento quando stabilisci una connessione con il driver ODBC per BigQuery. Devi annotare solo le informazioni corrispondenti al metodo di autenticazione che utilizzi.
Metodo di autenticazione Informazioni di autenticazione Esempio Proprietà della connessione (da impostare in un secondo momento) Account di servizio standard Chiave del service account (oggetto JSON) my-sa-keyKeyFilePathFederazione delle identità per i workload o per la forza lavoro Proprietà Segmento di pubblico del file di configurazione dell'account esterno //iam.googleapis.com/locations/global/...BYOID_AudienceUrlFile di recupero dei token e informazioni sull'ambiente {"file":"/path/to/file"}BYOID_CredentialSourceProgetto utente (solo per il pool di forza lavoro) my_projectBYOID_PoolUserProjectTipo di token STS id_tokenBYOID_SubjectTokenTypeEndpoint di scambio token STS https://sts.googleapis.com/v1/tokenBYOID_TokenUrlCredenziali predefinite dell'applicazione Nessuno N/D N/D
Installare e configurare il driver ODBC
Puoi installare e configurare il driver ODBC per BigQuery utilizzando un sistema operativo Windows o non Windows.
Windows
Installa il driver corrispondente all'architettura della tua applicazione:
- Scarica il
file
ODBCDriverforBigQuery_windows_x86.msiper le applicazioni a 32 bit. - Scarica il
file
ODBCDriverforBigQuery_windows_x64.msiper le applicazioni a 64 bit.
- Scarica il
file
Crea un nome origine dati (DSN) nel seguente modo:
- Dal menu Start di Windows, vai a Origini dati ODBC e seleziona la versione con la stessa bitness dell'applicazione client.
- Nella pagina Amministratore origini dati ODBC, fai clic sulla scheda Driver.
- Nell'elenco dei driver ODBC installati, individua ODBC Driver for BigQuery.
- Seleziona la scheda DSN di sistema per creare un DSN per tutti gli utenti o la scheda DSN utente per creare un DSN per l'utente corrente. I DSN di sistema sono generalmente consigliati perché alcune applicazioni caricano i dati utilizzando account utente diversi e potrebbero non rilevare altri DSN utente.
- Fai clic su Aggiungi.
- Nella finestra di dialogo Crea nuova origine dati, seleziona Driver ODBC per BigQuery, quindi fai clic su Fine. Si apre la finestra di dialogo Configurazione DSN del driver ODBC per BigQuery.
- Nel campo Nome origine dati, inserisci un nome per il DSN.
- Aggiungi le proprietà di connessione. Per un elenco completo delle proprietà, consulta Proprietà di connessione.
Non Windows
Installa il driver corrispondente al tuo sistema operativo:
- Scarica il
file
ODBCDriverforBigQuery_linux_latest.zipper Linux. - Scarica il
file
ODBCDriverforBigQuery_macos_latest.tar.gzper macOS.
- Scarica il
file
Estrai i contenuti del file ZIP o TAR scaricato.
Sposta i contenuti del file ZIP o TAR nella directory in cui vuoi installare il connettore. Il percorso dell'oggetto condiviso del driver ODBC per BigQuery è
INSTALL_DIR/lib/libgoogle_cloud_odbc_bq_driver.so, doveINSTALL_DIRè la directory di installazione.Aggiorna i file
.iniin modo che riflettano il nuovo percorso del connettore.Il seguente esempio aggiorna i file
.iniin un sistema Linux:unzip linux_odbc-driver.VERSION.zip -d linux_odbc-driver.VERSION/ cd ./linux_odbc-driver.VERSION export INSTALL_DIR=$(pwd) export ODBCINI=$INSTALL_DIR/odbc.ini export ODBCINSTINI=$INSTALL_DIR/odbcinst.ini export GOOGLEBIGQUERYODBCINI=$INSTALL_DIR/googlebigqueryodbc.ini
Sostituisci
VERSIONcon la versione del driver.
Stabilire una connessione
Per stabilire una connessione tra la tua applicazione e BigQuery con il driver ODBC per BigQuery, identifica la stringa di connessione. Puoi saltare questo passaggio se hai già configurato le proprietà di connessione tramite il DSN.
La stringa di connessione ha il seguente formato:
Driver=ODBC Driver for BigQuery;ProjectId=PROJECT_ID;OAuthType=AUTH_TYPE;AUTH_PROPS;OTHER_PROPS
Sostituisci quanto segue:
PROJECT_ID: l'ID del tuo progetto BigQuery.AUTH_TYPE: un numero che specifica il tipo di autenticazione che hai utilizzato. Seleziona una delle seguenti opzioni:0: per l'autenticazione del account di servizio3: per l'autenticazione delle credenziali predefinite dell'applicazione4: per l'autenticazione della federazione delle identità per i workload o della federazione delle identità per la forza lavoro
AUTH_PROPS: le informazioni di autenticazione che hai annotato quando ti sei autenticato in BigQuery, elencate nel formatoproperty_1=value_1; property_2=value_2;..., ad esempio,KeyFilePath=my-sa-key, se ti sei autenticato con un account di servizio.OTHER_PROPS(facoltativo): proprietà di connessione aggiuntive per il driver ODBC, elencate nel formatoproperty_1=value_1; property_2=value_2;.... Per un elenco completo delle proprietà di connessione, consulta Proprietà di connessione.
Proprietà di connessione
Le proprietà di connessione del driver ODBC sono parametri di configurazione che includi nella stringa di connessione quando stabilisci una connessione a un database. Il driver ODBC per BigQuery supporta le seguenti proprietà di connessione.
| Proprietà della connessione | Descrizione | Valore predefinito | Tipo di dati | Obbligatorio |
|---|---|---|---|---|
AdditionalProjects |
Progetti a cui il driver può accedere per query e operazioni sui metadati,
oltre al progetto principale impostato dalla proprietà ProjectId.
|
N/D | Stringa separata da virgole | No |
AllowHtapiForLargeResults |
Determina se il driver può utilizzare l'API BigQuery Storage di lettura. | 0 |
Booleano | No |
AllowLargeResults |
Determina se il driver elabora i risultati della query di dimensioni superiori a 128 MB quando la proprietà QueryDialect è impostata su BIG_QUERY. Se la proprietà QueryDialect è impostata su SQL, il driver elabora sempre i risultati di query di grandi dimensioni.
|
0 |
Booleano | No |
BYOID_AudienceUrl |
Contiene il nome della risorsa per il pool di identità del workload o il pool di forza lavoro e l'identificatore del provider in quel pool. | N/D | Stringa | Solo quando OAuthMechanism=4 |
BYOID_CredentialSource |
Imposta le informazioni necessarie per recuperare il token stesso, nonché alcune informazioni ambientali. | N/D | Stringa | Solo quando OAuthMechanism=4 |
BYOID_PoolUserProject |
Imposta il progetto quando si tratta di un pool della forza lavoro e non di un pool di Workload Identity. | N/D | Stringa | Solo quando OAuthMechanism=4 e si utilizza un pool forza lavoro |
BYOID_SubjectTokenType |
Imposta il tipo di token STS in base alla specifica di scambio di token OAuth 2.0. I valori previsti includono:
|
N/D | Stringa | Solo quando OAuthMechanism=4 |
BYOID_TokenUrl |
Imposta l'endpoint di scambio dei token STS. | https://sts.googleapis.com/v1/token |
Stringa | No |
DefaultDataset |
Funge da set di dati designato all'interno di un progetto a cui il driver fa riferimento automaticamente quando esegui query senza specificare esplicitamente un set di dati. | N/D | Stringa | No |
FilterTablesOnDefaultDataset |
Determina l'ambito dei metadati restituiti dai metodi dei metadati di tabelle o colonne. Se il valore è false, non viene applicato alcun filtro. Devi anche impostare la proprietà DefaultDataset per attivare il filtro.
|
FALSE |
Booleano | No |
EnableSession |
Determina se una connessione avvia una sessione. Se abilitata, la prima query eseguita da quella particolare connessione avvia una sessione e il driver passa l'ID sessione a tutte le query successive. | 0 |
Booleano | No |
JobCreationMode |
Consente di attivare il percorso di query a bassa latenza. Scegli una delle seguenti opzioni:
|
2 |
Numero intero | No |
KeyFilePath |
Il percorso della chiave del account di servizio quando si utilizza l'autenticazione delaccount di serviziot. | N/D | Stringa |
Solo quando OAuthMechanism=0
|
KMSKeyName |
Specifica il nome della chiave KMS da utilizzare per criptare e decriptare i dati. | N/D | Stringa | No |
LargeResultsDataSetId |
Specifica il set di dati di destinazione per l'archiviazione dei risultati di query di grandi dimensioni. | N/D | Stringa | No |
LargeResultsDatasetExpirationTime |
Specifica la durata di tutte le tabelle nel set di dati dei risultati di grandi dimensioni, in millisecondi. | 3600000 |
Lungo | No |
Location |
Specifica la posizione in cui il driver crea o esegue query sui set di dati. | N/D | Stringa | No |
LogLevel |
Limita i dettagli registrati dal driver durante le interazioni. Scegli una delle seguenti opzioni:
|
0 |
Numero intero | No |
LogPath |
Specifica la directory in cui il driver scrive i file di log. | N/D | Stringa | No |
LogFileCount |
Specifica il numero massimo di file di log da conservare. | 0 |
Numero intero | No |
LogFileSize |
Specifica la dimensione massima di ogni file di log in byte. | 0 |
Lungo | No |
MaxResults |
Specifica il numero di risultati per pagina nel risultato dell'API BigQuery. | 10000 |
Lungo | No |
MaxThreads |
Definisce il numero massimo di thread che il connettore può utilizzare per
l'elaborazione simultanea in un pool di thread. Per configurare questa proprietà come
impostazione a livello di connettore per i connettori non Windows, specificarla nel
file googlebigqueryodbc.ini.
|
8 |
Numero intero | No |
OAuthMechanism |
Il tipo di autenticazione. Scegli una delle seguenti opzioni:
|
N/D | Numero intero | Sì |
ProjectId |
L'ID progetto predefinito per l'autista. Il driver utilizza questo progetto per eseguire query e lo fattura per l'utilizzo delle risorse. | N/D | Stringa | Sì |
ProxyHost |
Nome host o indirizzo IP di un server proxy. | N/D | Stringa | No |
ProxyPort |
Numero di porta su cui il server proxy è in ascolto. | N/D | Stringa | No |
ProxyPwd |
Password per l'autenticazione durante la connessione tramite un server proxy. | N/D | Stringa | No |
ProxyUid |
Nome utente per l'autenticazione durante la connessione tramite un server proxy. | N/D | Stringa | No |
PrivateServiceConnectUris |
Endpoint personalizzati per sovrascrivere gli endpoint predefiniti. Esempi:
|
N/D | Stringa separata da virgole | No |
QueryDialect |
Specifica quale dialetto della query utilizzare. Utilizza SQL per
GoogleSQL (opzione altamente consigliata) e BIG_QUERY per
SQL precedente.
|
SQL |
Stringa | No |
QueryProperties |
Configura le proprietà che possono modificare il comportamento della query. | N/D | Map<String, String> | No |
UniverseDomain |
Specifica il dominio dell'universo per la tua organizzazione. | googleapis.com |
Stringa | No |
UseQueryCache |
Attiva la funzionalità di memorizzazione nella cache delle query in BigQuery. | true |
Booleano | No |
Mappatura dei tipi di dati
Quando esegui query tramite il driver ODBC per BigQuery, viene eseguito il seguente mapping dei tipi di dati:
| Tipo GoogleSQL | Tipo SQL ODBC |
|---|---|
INT64 | SQL_BIGINT |
BOOL | SQL_BIT |
DATE | SQL_TYPE_DATE |
FLOAT64 | SQL_DOUBLE |
TIME | SQL_TYPE_TIME |
TIMESTAMP | SQL_TYPE_TIMESTAMP |
DATETIME | SQL_TYPE_TIMESTAMP |
BYTES | SQL_VARBINARY |
STRING | SQL_VARCHAR |
ARRAY | SQL_VARCHAR |
STRUCT | SQL_VARCHAR |
INTERVAL | SQL_VARCHAR |
JSON | SQL_VARCHAR |
GEOGRAPHY | SQL_VARCHAR |
RANGE | SQL_VARCHAR |
NUMERIC | SQL_NUMERIC |
BIGNUMERIC | SQL_NUMERIC |
Esempi
Gli esempi seguenti mostrano come utilizzare le query con parametri e gli script con più istruzioni con il driver ODBC.
Query con parametri
// 1. Prepare statement std::string insert_stmt = "INSERT INTO MyTable VALUES (?, ?, ?)"; status = SQLPrepare(hstmt, (SQLCHAR*)insert_stmt.c_str(), SQL_NTS); // 2. Bind parameters std::string str_val = "example_string"; long long int_val = 12345; double float_val = 1.2345; // Bind string field status = SQLBindParameter( hstmt, 1, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_VARCHAR, 50, 0, (SQLPOINTER)str_val.c_str(), str_val.size(), NULL); // Bind integer field status = SQLBindParameter( hstmt, 2, SQL_PARAM_INPUT, SQL_C_UBIGINT, SQL_BIGINT, 0, 0, &int_val, 0, NULL); // Bind float field status = SQLBindParameter( hstmt, 3, SQL_PARAM_INPUT, SQL_C_DOUBLE, SQL_DOUBLE, 0, 0, &float_val, 0, NULL); // 3. Execute statement status = SQLExecute(hstmt);
Script con più istruzioni
// 1. Prepare and execute the multi-statement script std::string query = "CREATE OR REPLACE TABLE MyTable (StringField STRING, IntegerField INTEGER); " "INSERT INTO MyTable VALUES ('example', 123); " "SELECT * FROM MyTable;"; status = SQLExecDirect(hstmt, (SQLCHAR*)query.c_str(), SQL_NTS); // 2. Process results for each statement using SQLMoreResults do { SQLSMALLINT num_cols; status = SQLNumResultCols(hstmt, &num_cols); if (num_cols > 0) { // This is a result-returning statement (e.g., SELECT) while (SQLFetch(hstmt) == SQL_SUCCESS) { // Process rows... } } else { // This is a non-result statement (e.g., CREATE, INSERT) SQLLEN row_count; SQLRowCount(hstmt, &row_count); // Process affected rows... } } while (SQLMoreResults(hstmt) == SQL_SUCCESS);
Prezzi
Puoi scaricare il driver ODBC per BigQuery senza costi. Tuttavia, quando utilizzi il driver, si applicano i prezzi standard dell'analisi BigQuery.
Passaggi successivi
- Scopri di più sul driver JDBC per BigQuery.
- Esplora altri strumenti per sviluppatori BigQuery.