Instructions for querying Google BigQuery using the bq command-line tool. Useful for running SQL queries, exploring datasets, and exporting results.
Install
npx skillscat add sourcegraph/amp-contrib/bigquery Install via the SkillsCat registry.
BigQuery Skill
This skill enables you to query Google BigQuery using the bq command-line tool.
Authentication is already configured. The default project is project_id.
Use the project_id_exploration dataset as scratch space for temporary tables and experimentation.
The public dataset contains tables synced from the production Postgres database.
1. Explore Available Datasets
List datasets in the current project (defaults to project_id):
bq lsList datasets in a specific project:
bq ls --project_id=PROJECT_IDList tables in a dataset:
bq ls PROJECT_ID:DATASET_NAMEGet table schema:
bq show --schema --format=prettyjson PROJECT_ID:DATASET_NAME.TABLE_NAME2. Run Queries
Run a simple query:
bq query --use_legacy_sql=false 'SELECT * FROM `project.dataset.table` LIMIT 10'Run a query with formatted output:
bq query --use_legacy_sql=false --format=prettyjson 'YOUR_QUERY'Run a query and save to a destination table:
bq query --use_legacy_sql=false --destination_table=PROJECT:DATASET.NEW_TABLE 'YOUR_QUERY'Run a dry run to estimate costs:
bq query --use_legacy_sql=false --dry_run 'YOUR_QUERY'3. Export Results
Export to CSV:
bq query --use_legacy_sql=false --format=csv 'YOUR_QUERY' > results.csv4. Best Practices
- Always use
--use_legacy_sql=falsefor standard SQL syntax - Use
LIMITclauses when exploring data to reduce costs - Use
--dry_runto estimate query costs before running expensive queries - Use backticks around table references:
`project.dataset.table`
5. Common Patterns
Preview table data:
bq head -n 10 PROJECT:DATASET.TABLEGet table info (row count, size):
bq show --format=prettyjson PROJECT:DATASET.TABLEQuery with parameters:
bq query --use_legacy_sql=false --parameter='name:STRING:value' 'SELECT * FROM `table` WHERE col = @name'