news 2026/4/15 15:20:12

LangChain-08 Query SQL DB 通过GPT自动查询SQL

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
LangChain-08 Query SQL DB 通过GPT自动查询SQL

我们需要下载一个LangChain官方提供的本地小数据库。

安装依赖

SQL: https://raw.githubusercontent.com/lerocha/chinook-database/master/ChinookDatabase/DataSources/Chinook_Sqlite.sql Shell: pip install --upgrade --quiet langchain-core langchain-community langchain-openai

导入数据

我这里使用Navicat导入数据,你也可以通过别的方式导入(当然你有现成的数据库也可以,但是不要太大了,不然会消耗很多Token)。

编写代码

这里我使用了GPR 3.5 Turbo,效果不理想的话可以试试GPT 4或者GPT 4 Turbo

from langchain_core.prompts import ChatPromptTemplate from langchain_community.utilities import SQLDatabase from langchain_core.output_parsers import StrOutputParser from langchain_core.runnables import RunnablePassthrough from langchain_openai import ChatOpenAI template = """Based on the table schema below, write a SQL query that would answer the user's question: {schema} Question: {question} SQL Query:""" prompt = ChatPromptTemplate.from_template(template) db = SQLDatabase.from_uri("sqlite:///./Chinook.db") def get_schema(_): return db.get_table_info() def run_query(query): return db.run(query) model = ChatOpenAI( model="gpt-3.5-turbo", ) sql_response = ( RunnablePassthrough.assign(schema=get_schema) | prompt | model.bind(stop=[" SQLResult:"]) | StrOutputParser() ) message = sql_response.invoke({"question": "How many employees are there?"}) print(f"message: {message}")

运行结果

? python3 test08.py message: SELECT COUNT(*) AS totalEmployees FROM Employee;

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/11 18:38:31

LeetCode 172. Factorial Trailing Zeroes 题解

题目概述 LeetCode 172. Factorial Trailing Zeroes:给定一个整数 n,返回 n! 中尾随零(结尾连续的 0)的个数。leetcode​ 注意: n! n (n − 1) … 2 10 ≤ n ≤ 10^4Follow up:是否可以在对数时间复…

作者头像 李华
网站建设 2026/4/10 6:55:04

AWS OpenSearch Service TLS 策略升级指南

📋 概述 AWS OpenSearch Service 将于 2026 年 4 月 20 日停止支持 TLS 1.0 和 1.1 版本。本文详细介绍如何安全地将 OpenSearch 域的 TLS 策略升级到 TLS 1.2,确保服务的持续可用性和安全性。 🚨 重要通知 截止日期: 2026 年 4 月 20 日 影响: 使用 TLS 1.0/1.1 的域将…

作者头像 李华
网站建设 2026/4/10 7:31:54

深度学习毕设项目:基于人工智能深度学习的土豆疾病识别

博主介绍:✌️码农一枚 ,专注于大学生项目实战开发、讲解和毕业🚢文撰写修改等。全栈领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围:&am…

作者头像 李华
网站建设 2026/4/13 1:24:00

Spring Boot Admin与Kubernetes集成监控

摘要 本文深入探讨Spring Boot Admin与Kubernetes的集成监控方案,包括容器化部署、服务发现、资源监控等关键技术点。通过详细的技术解析和实践示例,帮助开发者构建基于Kubernetes的微服务监控体系。 1. 引言 Kubernetes作为容器编排的标准,与…

作者头像 李华
网站建设 2026/4/12 2:03:00

强烈安利!专科生毕业论文必备TOP9 AI论文平台

强烈安利!专科生毕业论文必备TOP9 AI论文平台 2026年专科生论文写作工具测评:为什么你需要这份榜单? 随着AI技术在学术领域的深入应用,越来越多的专科生开始借助智能工具提升论文写作效率。然而面对市场上琳琅满目的AI论文平台&am…

作者头像 李华
网站建设 2026/4/15 8:53:26

【毕业设计】机器学习 基于python-cnn深度学习的罗马数据集训练识别

博主介绍:✌️码农一枚 ,专注于大学生项目实战开发、讲解和毕业🚢文撰写修改等。全栈领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围:&am…

作者头像 李华