Google BigQuery
This is the implementation of the BigQuery data handler for MindsDB.
BigQuery is a fully-managed, serverless data warehouse that enables scalable analysis over petabytes of data. It is a Platform-as-a-Service that supports querying using ANSI SQL.
Implementation
This handler is implemented using the google-cloud-bigquery
Python library.
The required arguments to establish a connection are as follows:
project_id
is a globally unique identifier for your project.dataset
defines the default dataset. Tables from this dataset are shown in the object tree.service_account_keys
is a full path to the service account key file. This parameter is required but can be replaced byservice_account_json
.service_account_json
stores the content of a JSON file defined by theservice_account_keys
parameter. This parameter is required whenservice_account_keys
is not provided.
For more info about creating and managing the service account key visit this page.
If you installed MindsDB locally via pip, you need to install all handler dependencies manually. To do so, go to the handler’s folder (mindsdb/integrations/handlers/bigquery_handler) and run this command: pip install -r requirements.txt
.
Usage
In order to make use of this handler and connect to the BigQuery database in MindsDB, the following syntax can be used:
You can use either the service_account_keys
parameter or the service_account_json
parameter.
If you use MindsDB Cloud, it is recommended to provide the service_account_json
parameter, as in the example below.
If you use local installation of MindsDB, you can provide either the service_account_keys
parameter or the service_account_json
parameter, as in the example below.
The mydataset
dataset is the default one. The below queries are equivalent:
You can query from other datasets, like this:
You can use this established connection to query your dataset as follows: