import argparse
import os
import sys
from deepagents import create_deep_agent
from deepagents.backends import FilesystemBackend
from dotenv import load_dotenv
from langchain_anthropic import ChatAnthropic
from langchain_community.agent_toolkits import SQLDatabaseToolkit
from langchain_community.utilities import SQLDatabase
from rich.console import Console
from rich.panel import Panel
load_dotenv()
console = Console()
def create_sql_deep_agent():
"""Create and return a text-to-SQL Deep Agent"""
base_dir = os.path.dirname(os.path.abspath(__file__))
db_path = os.path.join(base_dir, "chinook.db")
db = SQLDatabase.from_uri(f"sqlite:///{db_path}", sample_rows_in_table_info=3)
model = ChatAnthropic(model="claude-sonnet-4-5-20250929", temperature=0)
toolkit = SQLDatabaseToolkit(db=db, llm=model)
sql_tools = toolkit.get_tools()
agent = create_deep_agent(
model=model,
memory=["./AGENTS.md"],
skills=[
"./skills/"
],
tools=sql_tools,
subagents=[],
backend=FilesystemBackend(root_dir=base_dir),
)
return agent
def main():
"""Main entry point for the SQL Deep Agent CLI"""
parser = argparse.ArgumentParser(
description="Text-to-SQL Deep Agent powered by LangChain Deep Agents and Claude Sonnet 4.5",
formatter_class=argparse.RawDescriptionHelpFormatter,
epilog="""
Examples:
python agent.py "What are the top 5 best-selling artists?"
python agent.py "Which employee generated the most revenue by country?"
python agent.py "How many customers are from Canada?"
""",
)
parser.add_argument(
"question",
type=str,
help="Natural language question to answer using the Chinook database",
)
args = parser.parse_args()
console.print(
Panel(f"[bold cyan]Question:[/bold cyan] {args.question}", border_style="cyan")
)
console.print()
console.print("[dim]Creating SQL Deep Agent...[/dim]")
agent = create_sql_deep_agent()
console.print("[dim]Processing query...[/dim]\n")
try:
result = agent.invoke(
{"messages": [{"role": "user", "content": args.question}]}
)
final_message = result["messages"][-1]
answer = (
final_message.content
if hasattr(final_message, "content")
else str(final_message)
)
console.print(
Panel(f"[bold green]Answer:[/bold green]\n\n{answer}", border_style="green")
)
except Exception as e:
console.print(
Panel(f"[bold red]Error:[/bold red]\n\n{str(e)}", border_style="red")
)
sys.exit(1)
if __name__ == "__main__":
main()