| title | bigquery-conversational-analytics | |
|---|---|---|
| type | docs | |
| weight | 1 | |
| description | A "bigquery-conversational-analytics" tool allows conversational interaction with a BigQuery source. | |
| aliases |
|
A bigquery-conversational-analytics tool allows you to ask questions about
your data in natural language.
This function takes a user's question (which can include conversational history for context) and references to specific BigQuery tables, and sends them to a stateless conversational API.
The API uses a GenAI agent to understand the question, generate and execute SQL queries and Python code, and formulate an answer. This function returns a detailed, sequential log of this entire process, which includes any generated SQL or Python code, the data retrieved, and the final text answer.
Note: This tool requires additional setup in your project. Please refer to the official Conversational Analytics API documentation for instructions.
It's compatible with the following sources:
bigquery-conversational-analytics accepts the following parameters:
user_query_with_context: The user's question, potentially including conversation history and system instructions for context.table_references: A JSON string of a list of BigQuery tables to use as context. Each object in the list must containprojectId,datasetId, andtableId. Example:'[{"projectId": "my-gcp-project", "datasetId": "my_dataset", "tableId": "my_table"}]'
The tool's behavior regarding these parameters is influenced by the
allowedDatasets restriction on the bigquery source:
- Without
allowedDatasetsrestriction: The tool can use tables from any dataset specified in thetable_referencesparameter. - With
allowedDatasetsrestriction: Before processing the request, the tool verifies that every table intable_referencesbelongs to a dataset in the allowed list. If any table is from a dataset that is not in the list, the request is denied.
kind: tool
name: ask_data_insights
type: bigquery-conversational-analytics
source: my-bigquery-source
description: |
Use this tool to perform data analysis, get insights, or answer complex
questions about the contents of specific BigQuery tables.You can optionally configure a
data agent
to provide additional context for the conversational analytics API. When a
dataAgent is specified, the tool uses the data agent context instead of inline
context.
kind: tools
name: ask_data_insights
type: bigquery-conversational-analytics
source: my-bigquery-source
dataAgent: projects/my-project/locations/us/dataAgents/my-agent-id
description: |
Use this tool to perform data analysis, get insights, or answer complex
questions about the contents of specific BigQuery tables.| field | type | required | description |
|---|---|---|---|
| type | string | true | Must be "bigquery-conversational-analytics". |
| source | string | true | Name of the source for chat. |
| description | string | true | Description of the tool that is passed to the LLM. |
| dataAgent | string | false | Full resource name of a data agent (e.g. projects/{project}/locations/{location}/dataAgents/{dataAgentId}). When set, the tool uses data agent context instead of inline context. |