Skip to main content

No project description provided

Project description

BigQuery Agents

This project implements a conversational agent powered by LangGraph and Google Vertex AI's Gemini model to troubleshoot BigQuery jobs. It utilizes custom tools to fetch job details and table schemas, enabling the agent to provide informed suggestions for fixing errors.

Scripts

  • bq_fix is an AI agent uses Gemini 2.0 Flash. Agent suggests fixes to a problematic query by getting Bigquery job id from user. It uses BigQueryJobDetailsTool and BigQueryTableSchemaTool to get the query and error text and suggests some resolutions. If the error includes data type related ones, it uses BigQueryTableSchemaTool tool to get the table schema for more accurate suggestions.
  • bq_fix_basic is a basic version which does not have the schema lookup functionality. can be useful to resolve syntax issues but not that efficient if the error is related to a column data type compared to bq_fix.

Features

  • BigQuery Job Details Retrieval: Fetches details of a BigQuery job, including the query and any error messages.
  • BigQuery Table Schema Retrieval: Retrieves the schema of a BigQuery table, including column names and data types.
  • Error Analysis and Fix Suggestions: Analyzes job details and errors to suggest possible fixes, leveraging table schema information when necessary.
  • Conversational Interface: Allows users to interact with the agent through a command-line interface.
  • LangGraph State Management: Uses LangGraph to manage the conversation flow and state, including messages, job details, and table schemas.
  • Mermaid Graph Visualization: Generates a Mermaid diagram of the LangGraph flow, saved as graph.jpg.

Prerequisites

  • Python 3.12+
  • Google Cloud Platform (GCP) account with BigQuery enabled
  • PROJECT_ID environment variable set to your GCP project ID or hardcoded in the script.
  • Poetry for dependency management

Installation using pip

  1. Install the pypi package:

    pip install bigquery_agents
    

Installation via Github

  1. Clone the repository:

    git clone https://github.com/samkaradag/bigquery-agents.git
    cd bigquery-agents
    
  2. Install dependencies using Poetry:

    poetry install
    

Usage

  1. Set your GCP project ID:

    export PROJECT_ID="your-gcp-project-id"
    

    Or change the PROJECT_ID variable inside the python script.

  2. Authenticate with GCP:

    gcloud auth application-default login
    
  3. Run the agent using the bq_fix:

    bq_fix
    

Langgraph graph visualization

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

bigquery_agents-0.1.15.tar.gz (29.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

bigquery_agents-0.1.15-py3-none-any.whl (33.7 kB view details)

Uploaded Python 3

File details

Details for the file bigquery_agents-0.1.15.tar.gz.

File metadata

  • Download URL: bigquery_agents-0.1.15.tar.gz
  • Upload date:
  • Size: 29.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.0.1 CPython/3.12.9 Darwin/24.3.0

File hashes

Hashes for bigquery_agents-0.1.15.tar.gz
Algorithm Hash digest
SHA256 48536721d788dcdb9b61e3bbe9177364d99d443d07e3ba81eaf7477dcf01347b
MD5 13ad2bcf3e2b2910db5553256f3b7acd
BLAKE2b-256 1f6042d1eded8317ecf89f4a092a06bccf997ad8547e18fc10ea61133a580ed4

See more details on using hashes here.

File details

Details for the file bigquery_agents-0.1.15-py3-none-any.whl.

File metadata

  • Download URL: bigquery_agents-0.1.15-py3-none-any.whl
  • Upload date:
  • Size: 33.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.0.1 CPython/3.12.9 Darwin/24.3.0

File hashes

Hashes for bigquery_agents-0.1.15-py3-none-any.whl
Algorithm Hash digest
SHA256 e60eeb0c989c8b9a845e1c910e33fb6733a73af763a2c40d6a23ec2ba879adcb
MD5 a252f0366881315263be2acb0d2819e9
BLAKE2b-256 8e6b39d11a82aa48faf61789285ab85c51f22f6337213af9bb8f291b25f624bb

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page