llama-index tools waii integration
Project description
Waii Tool
This tool connects to database connections managed by Waii, which allows generic SQL queries, do performance analyze, describe a SQL query, and more.
Usage
First you need to create a waii.ai account, you request an account from here.
Initialize the tool with your account credentials:
from llama_index.tools.waii import WaiiToolSpec
waii_tool = WaiiToolSpec(
url="https://tweakit.waii.ai/api/",
# API Key of Waii (not OpenAI API key)
api_key="...",
# Connection key of WAII connected database, see https://github.com/waii-ai/waii-sdk-py#get-connections
database_key="...",
)
Tools
The tools available are:
get_answer: Get answer to natural language question (which generate a SQL query, run it, explain the result)describe_query: Describe a SQL queryperformance_analyze: Analyze performance of a SQL query (by query_id)diff_query: Compare two SQL queriesdescribe_dataset: Describe dataset, such as table, schema, etc.transcode: Transcode SQL query to another SQL dialectget_semantic_contexts: Get semantic contexts of a SQL querygenerate_query_only: Generate SQL query only (not run it)run_query: Run a SQL query
You can also load the data directly call load_data
Examples
Load data
documents = waii_tool.load_data("Get all tables with their number of columns")
index = VectorStoreIndex.from_documents(documents).as_query_engine()
print(index.query("Which table contains most columns?"))
Use as a Tool
Initialize the agent:
from llama_index.core.agent.workflow import FunctionAgent
from llama_index.llms.openai import OpenAI
agent = FunctionAgent(
tools=waii_tool.to_tool_list(), llm=OpenAI(model="gpt-4-1106-preview")
)
Ask simple question
from llama_index.core.workflow import Context
ctx = Context(agent)
print(
await agent.run(
"Give me top 3 countries with the most number of car factory", ctx=ctx
)
)
print(
await agent.run("What are the car factories of these countries", ctx=ctx)
)
Do performance analyze
from llama_index.core.workflow import Context
ctx = Context(agent)
print(
await agent.run(
"Give me top 3 longest running queries, and their duration.", ctx=ctx
)
)
print(await agent.run("analyze the 2nd-longest running query", ctx=ctx))
Diff two queries
previous_query = """
SELECT
employee_id,
department,
salary,
AVG(salary) OVER (PARTITION BY department) AS department_avg_salary,
salary - AVG(salary) OVER (PARTITION BY department) AS diff_from_avg
FROM
employees;
"""
current_query = """
SELECT
employee_id,
department,
salary,
MAX(salary) OVER (PARTITION BY department) AS department_max_salary,
salary - AVG(salary) OVER (PARTITION BY department) AS diff_from_avg
FROM
employees;
LIMIT 100;
"""
print(
await agent.run(
f"tell me difference between {previous_query} and {current_query}",
ctx=ctx,
)
)
Describe dataset
print(await agent.run("Summarize the dataset", ctx=ctx))
print(
await agent.run(
"Give me questions which I can ask about this dataset", ctx=ctx
)
)
Describe a query
q = """
SELECT
employee_id,
department,
salary,
AVG(salary) OVER (PARTITION BY department) AS department_avg_salary,
salary - AVG(salary) OVER (PARTITION BY department) AS diff_from_avg
FROM
employees;
"""
print(await agent.run(f"what this query can do? {q}", ctx=ctx))
Migrate query to another dialect
q = """
from pyspark.sql import SparkSession
from pyspark.sql.functions import avg, col
from pyspark.sql.window import Window
# Initialize Spark session
spark = SparkSession.builder.appName("example").getOrCreate()
# Assuming you have a DataFrame called 'employees'
# If not, you need to read your data into a DataFrame first
# Define window specification
windowSpec = Window.partitionBy("department")
# Perform the query
result = (employees
.select(
col("employee_id"),
col("department"),
col("salary"),
avg("salary").over(windowSpec).alias("department_avg_salary"),
(col("salary") - avg("salary").over(windowSpec)).alias("diff_from_avg")
))
# Show the result
result.show()
"""
print(
await agent.run(f"translate this pyspark query {q}, to Snowflake", ctx=ctx)
)
Use Waii API directly
You can also use Waii API directly, see here
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file llama_index_tools_waii-0.5.0.tar.gz.
File metadata
- Download URL: llama_index_tools_waii-0.5.0.tar.gz
- Upload date:
- Size: 6.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.9 {"installer":{"name":"uv","version":"0.10.9","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6b88ae6fa83b83b682e3a9caddd6ab4553d63c9079e861b8e4926a87693d95e2
|
|
| MD5 |
cf2613703ec7748f517d83b7084d6682
|
|
| BLAKE2b-256 |
583af0a58dde8432aaab95a437ce0e77f13f40e6ba43a2f85e4a693a83c63326
|
File details
Details for the file llama_index_tools_waii-0.5.0-py3-none-any.whl.
File metadata
- Download URL: llama_index_tools_waii-0.5.0-py3-none-any.whl
- Upload date:
- Size: 6.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.9 {"installer":{"name":"uv","version":"0.10.9","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a6399c9efe6ba24110beb7f67259f07c28bd0eae186abeb5971dcb5128d1765d
|
|
| MD5 |
34c744c81da1ea46702dfd06780452db
|
|
| BLAKE2b-256 |
1403c0c6f84acdf26af79cddbc260e50ef07a415d3bced0ef4339ea866fbd167
|