Skip to main content

An open-source Generative AI (GenAI) application designed to provide users

Project description

SQLRAG

Project Logo

SQLRAG allows users to query databases using natural language and receive results as SQL code and beautiful visualizations. Powered by Large Language Models (LLMs), SQLRAG supports both OpenAI models and open-source alternatives from GPT4All. Additionally, Redis caching is employed for optimized performance, and users can choose between CPU and GPU processing for open-source models.

Table of Contents

Description

SQLRAG is a Python package that lets users query their databases using simple natural language prompts. SQLRAG translates these prompts into SQL, executes the queries, and returns results as SQL code, data, and visualizations using either Matplotlib or Chart.js. It supports both open-source LLMs from GPT4All and paid models like OpenAI, giving users flexibility in model choice.

Redis caching is used to speed up responses for repeated queries, and users can opt for GPU processing with open-source models for faster execution.

Features

  • Natural Language Queries: Input your queries in plain language, and SQLRAG will convert them into SQL statements.
  • Data Visualization: Generate charts using Python's Matplotlib or JavaScript's Chart.js.
  • Model Flexibility: Supports both OpenAI models and open-source alternatives like GPT4All.
  • Redis Caching: Improves response times for repeated queries by caching previous results.
  • Supports CPU and GPU: Open-source models can run on both CPU and GPU, providing performance flexibility.

Getting Started

Prerequisites

  • Python 3.10 or higher
  • A compatible database (PostgreSQL, MySQL, SQLite, etc.)
  • Redis for caching (optional but recommended)
  • An OpenAI API key (if using OpenAI models)

Installation

SQLRAG is distributed as a Python package and can be installed via pip.

  1. Install the package:

    pip install sqlrag
    
  2. Set environment variables (if using OpenAI):

    export OPENAI_API_KEY=your_openai_key
    

That's it! Now you’re ready to use SQLRAG.

Usage

For Open-Source Models

You can use open-source models from GPT4All with SQLRAG. Here's how:

from sqlrag.open_sql_rag import OpenSQLRAG

# Initialize SQLRAG with your database and model
sql_rag = OpenSQLRAG("sqlite:///mydb.db", model_name="Meta-Llama-3-8B-Instruct.Q4_0.gguf", is_openai=False)

# Generate SQL code and a chart
data = sql_rag.generate_code_and_sql({"chart_type": "chart.js", "query": "List out all customers"})

# Output the generated SQL code and data
print(data)

# Check available open-source models and supported GPUs
print(sql_rag.get_open_source_models())
print(sql_rag.get_gpus_list())

For OpenAI Models

If you have an OpenAI API key, you can use OpenAI models with SQLRAG as follows:

from sqlrag.open_sql_rag import OpenSQLRAG

# Initialize SQLRAG with your database (OpenAI by default)
sql_rag = OpenSQLRAG("sqlite:///mydb.db")

# Generate SQL code and a chart
data = sql_rag.generate_code_and_sql({"chart_type": "chart.js", "query": "List out all customers"})

# Output the generated SQL code and data
print(data)

Redis Caching

SQLRAG automatically uses Redis to cache results of frequently used queries, speeding up the response time for repeated requests.

API Hosting

While SQLRAG is primarily a Python package, you can also expose it as an API if desired. However, it’s primarily designed for use as a Python library for direct database querying and data visualization.

Contributing

We welcome contributions to SQLRAG! Whether it's reporting bugs, submitting features, or writing documentation, feel free to open a pull request or issue. See CONTRIBUTING.md for more details.

License

SQLRAG is licensed under the MIT License. See LICENSE.md for further information.

Acknowledgments

Special thanks to the developers of GPT4All, OpenAI, and Redis for their open-source contributions. Their work has made this project possible.

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

sqlrag-0.1.dev43.tar.gz (601.8 kB view details)

Uploaded Source

Built Distribution

sqlrag-0.1.dev43-py3-none-any.whl (13.2 kB view details)

Uploaded Python 3

File details

Details for the file sqlrag-0.1.dev43.tar.gz.

File metadata

  • Download URL: sqlrag-0.1.dev43.tar.gz
  • Upload date:
  • Size: 601.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.6

File hashes

Hashes for sqlrag-0.1.dev43.tar.gz
Algorithm Hash digest
SHA256 4c7fb19164a85f1c87f6e256118cf9c2a52ad6a01cccc5a62097644a04ebda10
MD5 1e70ef4951c6abea40246760150bff07
BLAKE2b-256 5c3ce86d9d55fc2341264cd912b3d0938e5d6d7cb289711fab12f1f1be238513

See more details on using hashes here.

File details

Details for the file sqlrag-0.1.dev43-py3-none-any.whl.

File metadata

  • Download URL: sqlrag-0.1.dev43-py3-none-any.whl
  • Upload date:
  • Size: 13.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.6

File hashes

Hashes for sqlrag-0.1.dev43-py3-none-any.whl
Algorithm Hash digest
SHA256 61805b49e7e70c25f3199bc7a2dde461b35186e2858f73df62939f6028f2923d
MD5 3af7270edf3d4d6399a889694d73f9c9
BLAKE2b-256 550a25cd7193633f80a344ae56051e68c9bb69f30590f9c0ec1aa77f6294c3b1

See more details on using hashes here.

Supported by

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