Create Spanner external datasets
This document describes how to create an external dataset (also known as a federated dataset) in BigQuery that's linked to an existing database in Spanner.
An external dataset is a connection between BigQuery and an external data source at the dataset level. It lets you query transactional data in Spanner databases with GoogleSQL without needing to copy or import all of the data from Spanner to BigQuery storage. These query results are stored in BigQuery.
The tables in an external dataset are automatically populated from the tables in the corresponding external data source. You can query these tables directly in BigQuery, but you cannot make modifications, additions, or deletions. However, any updates that you make in the external data source are automatically reflected in BigQuery.
When you query Spanner, query results are by default saved in temporary tables. They can also optionally be saved as a new BigQuery table, joined with other tables, or merged with existing tables using DML.
Required permissions
To get the permission that
you need to create an external dataset,
ask your administrator to grant you the
BigQuery User (roles/bigquery.user
)
IAM role.
For more information about granting roles, see Manage access to projects, folders, and organizations.
This predefined role contains the
bigquery.datasets.create
permission,
which is required to
create an external dataset.
You might also be able to get this permission with custom roles or other predefined roles.
For more information about IAM roles and permissions in BigQuery, see Introduction to IAM.
Use a CLOUD_RESOURCE
connection
Optionally, Spanner external datasets can use a CLOUD_RESOURCE
connection to interact with your Spanner database, so that you can provide a user access to Spanner data through BigQuery, without giving them direct access to the Spanner database. Because the service account from CLOUD_RESOURCE
connection handles retrieving data from the Spanner, you only have to grant users access to the Spanner external dataset.
Before you create Spanner external datasets with a CLOUD_RESOURCE
connection, do the following:
Create a connection
You can create or use an existing CLOUD_RESOURCE
connection to connect to Spanner. To create
the Cloud resource connection, follow the steps on the Create a Cloud resource
connection
page.
After you create the connection, open it, and in the Connection info pane, copy the service account ID. You need this ID when you configure permissions for the connection. When you create a connection resource, BigQuery creates a unique system service account and associates it with the connection.
Set up access
You must give the new connection read access to your
Spanner instance or database. It is recommended to use
Cloud Spanner Database Reader with DataBoost (roles/spanner.databaseReaderWithDataBoost
) predefined IAM role.
Follow these steps to grant access to database-level roles for the service account that you copied earlier from the connection:
Go to the Spanner Instances page.
Click the name of the instance that contains your database to go to the Instance details page.
In the Overview tab, select the checkbox for your database.
The Info panel appears.Click Add principal.
In the Add principals panel, in New principals, enter the service account ID that you copied earlier.
In the Select a role field, select Cloud Spanner Database Reader with DataBoost role.
Click Save.
Create an external dataset
To create an external dataset, do the following:
Console
Open the BigQuery page in the Google Cloud console.
In the Explorer panel, select the project where you want to create the dataset.
Expand the
Actions option and click Create dataset.On the Create dataset page, do the following:
- For Dataset ID, enter a unique dataset name.
- For Location type, choose a location for the dataset, such as
us-central1
or multiregionus
. After you create a dataset, the location can't be changed. For External Dataset, do the following:
- Check the box next to Link to an external dataset.
- For External dataset type, select
Spanner
. - For External source, enter the full identifier of your Spanner database in the following format:
projects/PROJECT_ID/instances/INSTANCE/databases/DATABASE
. For example:projects/my_project/instances/my_instance/databases/my_database
. - Optionally, for Database role enter the name of a Spanner database role. For more information read about Database roles used for creating Spanner Connections
- Optionally, check the box next to Use a Cloud Resource connection to create the external dataset with a connection.
Leave the other default settings as they are.
Click Create dataset.
SQL
Use the
CREATE EXTERNAL SCHEMA
data definition language (DDL) statement.
In the Google Cloud console, go to the BigQuery page.
In the query editor, enter the following statement:
CREATE EXTERNAL SCHEMA DATASET_NAME OPTIONS ( external_source = 'SPANNER_EXTERNAL_SOURCE', location = 'LOCATION'); /* Alternatively, create with a connection: */ CREATE EXTERNAL SCHEMA DATASET_NAME WITH CONNECTION
PROJECT_ID.LOCATION.CONNECTION_NAME
OPTIONS ( external_source = 'SPANNER_EXTERNAL_SOURCE', location = 'LOCATION');Replace the following:
DATASET_NAME
: the name of your new dataset in BigQuery.SPANNER_EXTERNAL_SOURCE
: the full, qualified Spanner database name, with a prefix identifying the source, in the following format:google-cloudspanner://[DATABASE_ROLE@]/projects/PROJECT_ID/instances/INSTANCE/databases/DATABASE
. For example:google-cloudspanner://admin@/projects/my_project/instances/my_instance/databases/my_database
orgoogle-cloudspanner:/projects/my_project/instances/my_instance/databases/my_database
.LOCATION
: the location of your new dataset in BigQuery, for example,us-central1
. After you create a dataset, you can't change its location.- (Optional)
CONNECTION_NAME
: the name of your Cloud resource connection.
Click
Run.
For more information about how to run queries, see Run an interactive query.
bq
In a command-line environment, create an external dataset by using the
bq mk
command:
bq --location=LOCATION mk --dataset \ --external_source SPANNER_EXTERNAL_SOURCE \ DATASET_NAME
Alternatively, create with a connection:
bq --location=LOCATION mk --dataset \ --external_source SPANNER_EXTERNAL_SOURCE \ --connection_id PROJECT_ID.LOCATION.CONNECTION_NAME \ DATASET_NAME
Replace the following:
LOCATION
: the location of your new dataset in BigQuery—for example,us-central1
. After you create a dataset, you can't change its location. You can set a default location value by using the.bigqueryrc
file.SPANNER_EXTERNAL_SOURCE
: the full, qualified Spanner database name, with a prefix identifying the source, in the following format:google-cloudspanner://[DATABASE_ROLE@]/projects/PROJECT_ID/instances/INSTANCE/databases/DATABASE
. For example:google-cloudspanner://admin@/projects/my_project/instances/my_instance/databases/my_database
orgoogle-cloudspanner:/projects/my_project/instances/my_instance/databases/my_database
.DATASET_NAME
: the name of your new dataset in BigQuery. To create a dataset in a project other than your default project, add the project ID to the dataset name in the following format:PROJECT_ID
:DATASET_NAME
.- (Optional)
CONNECTION_NAME
: the name of your Cloud resource connection.
Terraform
Use the
google_bigquery_dataset
resource.
To authenticate to BigQuery, set up Application Default Credentials. For more information, see Set up authentication for client libraries.
The following example creates a Spanner external dataset:
To apply your Terraform configuration in a Google Cloud project, complete the steps in the following sections.
Prepare Cloud Shell
- Launch Cloud Shell.
-
Set the default Google Cloud project where you want to apply your Terraform configurations.
You only need to run this command once per project, and you can run it in any directory.
export GOOGLE_CLOUD_PROJECT=PROJECT_ID
Environment variables are overridden if you set explicit values in the Terraform configuration file.
Prepare the directory
Each Terraform configuration file must have its own directory (also called a root module).
-
In Cloud Shell, create a directory and a new
file within that directory. The filename must have the
.tf
extension—for examplemain.tf
. In this tutorial, the file is referred to asmain.tf
.mkdir DIRECTORY && cd DIRECTORY && touch main.tf
-
If you are following a tutorial, you can copy the sample code in each section or step.
Copy the sample code into the newly created
main.tf
.Optionally, copy the code from GitHub. This is recommended when the Terraform snippet is part of an end-to-end solution.
- Review and modify the sample parameters to apply to your environment.
- Save your changes.
-
Initialize Terraform. You only need to do this once per directory.
terraform init
Optionally, to use the latest Google provider version, include the
-upgrade
option:terraform init -upgrade
Apply the changes
-
Review the configuration and verify that the resources that Terraform is going to create or
update match your expectations:
terraform plan
Make corrections to the configuration as necessary.
-
Apply the Terraform configuration by running the following command and entering
yes
at the prompt:terraform apply
Wait until Terraform displays the "Apply complete!" message.
- Open your Google Cloud project to view the results. In the Google Cloud console, navigate to your resources in the UI to make sure that Terraform has created or updated them.
API
Call the
datasets.insert
method
with a defined dataset resource
and externalDatasetReference
field
for your Spanner database.
Note that names of the tables in the external datasets are case insensitive.
When you create the external datasets with a CLOUD_RESOURCE
connection,
you need to have the bigquery.connections.delegate
permission (available from the BigQuery Connection Admin role) on the connection
that is used by the external datasets.
Control access to tables
Spanner external datasets support end-user credentials (EUC). That means that access to the Spanner tables from external datasets is controlled by Spanner. Users can query these tables only if they have access granted in Spanner.
Spanner external datasets also support access delegation. Access delegation decouples access to the Spanner tables from external datasets and the direct access to the underlying Spanner tables. A Cloud resource connection associated with a service account is used to connect to the Spanner. Users can query these Spanner tables from external datasets even if they don't have access granted in Spanner.
List tables in an external dataset
To list the tables that are available for query in your external dataset, see Listing datasets.
Get table information
To get information on the tables in your external dataset, such as schema details, see Get table information.
Query Spanner data
Querying tables in external datasets is the same as querying tables in any other BigQuery dataset. However, data modification operations (DML) aren't supported.
Queries against tables in Spanner external datasets use Data Boost by default and it cannot be changed. Because of that you need additional permissions to run such queries.
Create a view in an external dataset
You can't create a view in a external dataset. However, you can create a view in a standard dataset that's based on a table in an external dataset. For more information, see Create views.
Delete a external dataset
Deleting a external dataset is the same as deleting any other BigQuery dataset. Deleting external datasets does not impact tables in the Spanner database. For more information, see Delete datasets.
Limitations
- BigQuery federated queries limitations apply.
- Only tables from a default Spanner schema are accessible in BigQuery. Tables from names schemas aren't supported.
- Primary and foreign keys defined in Spanner database aren't visible in BigQuery.
- If a table in Spanner database contains a column of a type that isn't supported by BigQuery then this column won't be accessible on BigQuery side.
- You can't add, delete, or update data or metadata in tables in a Spanner external dataset.
- You can't create new tables, views, or materialized views in a Spanner external dataset.
INFORMATION_SCHEMA
views aren't supported.- Metadata caching isn't supported.
- Dataset-level settings that are related to table creation defaults don't affect external datasets because you can't create tables manually.
- Spanner databases that use PostgreSQL dialect aren't supported.
- Write API and Read API aren't supported.
- Row-level security, column-level security, and data masking aren't supported.
- Materialized views based on tables from Spanner external datasets aren't supported.
- Integration with Dataplex Universal Catalog isn't supported. For example, data profiles and data quality scans aren't supported.
- Tags on a table level aren't supported.
- SQL auto completion does not work with Spanner external tables when you write queries.
- Scan with Sensitive Data Protection isn't supported for external datasets.
- Sharing with BigQuery sharing (formerly Analytics Hub) isn't supported for external datasets.
- If the Spanner external dataset uses end-user credentials (EUC), you can create an authorized view that references the external dataset. However, when this view is queried, then EUC of a person who executes a query will be sent to Spanner.
- If the Spanner external dataset uses a Cloud resource connection for access delegation, you can create an authorized view or an authorized routine that references the external dataset.
What's next
- Learn more about Spanner federated queries.