Create saved queries
When you write SQL in the query editor, you can save your query and share your query with others. Saved queries are BigQuery Studio code assets powered by Dataform.
For more information on deleting saved queries and managing saved query history, see Manage saved queries.
Enable BigQuery Studio
Follow the instructions at Enable BigQuery Studio for asset management to save, share, and manage versions of code assets such as saved queries.
Required permissions
Set the appropriate permissions to create, edit, or view saved queries.
All users with the
Dataform Admin (roles/dataform.admin
) role
have owner access to all saved queries created in the project.
For more information about BigQuery Identity and Access Management (IAM), see Access control with IAM.
Permissions to create saved queries
To create and run saved queries, you need the following IAM permissions:
dataform.locations.get
dataform.locations.list
dataform.repositories.list
dataform.repositories.create
You can get these permissions from the following IAM roles:
- BigQuery Job User (
roles/bigquery.jobUser
) - BigQuery Read Session User (
roles/bigquery.readSessionUser
)
Permissions to edit saved queries
To edit and run saved queries, you need the following IAM roles:
- BigQuery Job User (
roles/bigquery.jobUser
) - BigQuery Read Session User (
roles/bigquery.readSessionUser
) - Code Editor (
roles/dataform.codeEditor
)
Permissions to view saved queries
To view and run saved queries, you need the following IAM roles:
- BigQuery Job User (
roles/bigquery.jobUser
) - BigQuery Read Session User (
roles/bigquery.readSessionUser
) - Code Viewer (
roles/dataform.codeViewer
)
Set the default region for code assets
If this is the first time you are creating a code asset, set the default region for code assets. You can't change the region for a code asset after it is created.
Create saved queries
To create a saved query, follow these steps:
In the Google Cloud console, go to the BigQuery page.
Click
SQL query.In the query editor, enter a valid SQL query. For example, you can query a public dataset:
SELECT name, SUM(number) AS total FROM `bigquery-public-data.usa_names.usa_1910_2013` GROUP BY name ORDER BY total DESC LIMIT 10;
Click Save Query > Save query.
In the Save query dialog, type a name for the saved query.
Optional: To change the region used by this saved query and all other code assets in the future, select a new region in Region.
Click Save.
Share saved queries
To share a saved query with a user, you first grant that user access to the saved query and add them to an appropriate IAM role. Then you generate a link to the saved query and share that link with the user.
In the Google Cloud console, go to the BigQuery page.
In the Explorer pane, expand your project and the Queries folder, and if necessary, the Shared queries folder. Find and click the saved query that you want to grant access to.
Click
Share, and then click Manage permissions.In the Manage permissions pane, click Add user/group.
In the New principals field, enter a principal.
In the Role list, select one of the following roles:
- Code Owner: can perform any action on the saved query, including deleting or sharing it.
- Code Editor: can edit the query.
- Code Viewer: can view the query.
Optional: To view a complete list of roles and advanced sharing settings, click Advanced sharing.
Click Save.
To return to the saved query info, click Close.
To generate a link to the saved query, click
Share, and then click Get link.The link is copied to your clipboard.
Open a saved query version as a new query
To open any version of an existing saved query as a new query, follow these steps:
In the Google Cloud console, go to the BigQuery page.
In the Explorer pane, expand your project and the Queries folder, and if necessary, the Shared queries folder. Select a saved query.
Select the Activity pane.
Click
View actions next to a saved query version and then click Open as new query.
Update saved queries
If you update a saved query, you can save the changes in a new version of the query.
In the Google Cloud console, go to the BigQuery page.
In the Explorer pane, expand your project and the Queries folder, and if necessary, the Shared queries folder. Click the name of a saved query to open it.
Modify the query.
To save the modified query, click Save Query > Save query.
A new version of the query is created, which you can see in the Activity pane.
Upload saved queries
You can upload a local SQL query to use it as a saved query in BigQuery Studio. The uploaded saved query is then also visible in the BigQuery page of the Google Cloud console.
To upload a saved query, follow these steps:
In the Google Cloud console, go to the BigQuery page.
In the Explorer pane, expand your project, and then do one of the following:
- Next to Queries, click > Upload SQL query. View actions
- Next to the Google Cloud project name, click > Upload to project > SQL query. View actions
In the Upload SQL dialog, in the SQL field, click Browse, and then select the query that you want to upload.
Optional: In the SQL name field, edit the name of the query.
In the Region field, select the region where you want to upload your saved query.
Click Upload.
Your saved query appears in the Explorer pane.
Classic saved queries
Use the following sections to learn how to create and update classic saved queries. For more information on sharing, migrating, and deleting classic saved queries, see Classic saved queries.
Required permissions for classic saved queries
The following IAM permissions are required to create, view, update, and delete classic saved queries:
- Private classic saved queries:
- Creating private classic saved queries requires no special permissions. You can save a private query in any project, but only you can view, update, or delete the query.
- Project-level classic saved queries:
- Creating a project-level classic saved query requires
bigquery.savedqueries.create
permissions. Thebigquery.admin
predefined role includesbigquery.savedqueries.create
permissions. - Viewing a project-level classic saved query requires
bigquery.savedqueries.get
andbigquery.savedqueries.list
permissions. Thebigquery.admin
andbigquery.user
predefined roles includebigquery.savedqueries.get
andbigquery.savedqueries.list
permissions. - Updating a project-level classic saved query requires
bigquery.savedqueries.update
permissions. Thebigquery.admin
predefined role includesbigquery.savedqueries.update
permissions. - Deleting a project-level classic saved query requires
bigquery.savedqueries.delete
permissions. Thebigquery.admin
predefined role includesbigquery.savedqueries.delete
permissions.
- Creating a project-level classic saved query requires
- Public classic saved queries:
- Creating public classic saved queries requires no special permissions. You can save a public classic saved query in any project, but only you can update or delete the query. Anyone with the link can view a public classic saved query.
For more information on IAM roles in BigQuery, see Predefined roles and permissions.
Create classic saved queries
In the Google Cloud console, go to the BigQuery page.
Click
SQL query.In the query editor, enter a valid SQL query. For example, you can query a public dataset:
SELECT name, SUM(number) AS total FROM `bigquery-public-data.usa_names.usa_1910_2013` GROUP BY name ORDER BY total DESC LIMIT 10;
Click Save Query (Classic) > Save query (Classic).
In the Save query dialog, enter a name for your query, and then set Visibility to one of the following options:
- Personal (editable only by you) for a private clasic shared query.
- Project (editable by principals with appropriate permissions) for a project-level classic saved query.
- Public for a public classic saved query.
Click Save.
Share classic saved queries
You can share classic saved queries that you have given project or public visibility. Project visibility allows principals with the required permissions to view, update, or delete the query. Public visibility allows anyone with the query link to view but not update or delete the query.
You share a classic saved query with other users by generating and sharing a link to the classic saved query.
To run a classic shared query, users must have access to the data that the query accesses. For more information, see Grant access to a dataset.
If you are plan to share a classic saved query, consider including a comment in the query that describes its purpose.
- In the Explorer pane, expand your project and the (Classic) Queries folder, and then find the classic saved query you want to share.
- Click View actions next to the query and then click Get link.
- Share the link with the users you want to grant access to the query.
Update classic saved queries
In the Google Cloud console, go to the BigQuery page.
In the Explorer pane, expand your project and the (Classic) Queries folder, and if necessary, the Project queries folder.
Click the name of a classic saved query to open it.
Modify the query.
To save the modified query, click Save Query (Classic) > Save query (Classic).
What's next
- Learn how to manage saved queries.