LangChain-09 Query SQL DB With RUN GPT 查询数据库 并 执行SQL 返回结果

安装依赖

pip install --upgrade --quiet langchain-core langchain-community langchain-openai

编写代码

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() ) template = """Based on the table schema below, question, sql query, and sql response, write a natural language response: {schema} Question: {question} SQL Query: {query} SQL Response: {response}""" prompt_response = ChatPromptTemplate.from_template(template) full_chain = ( RunnablePassthrough.assign(query=sql_response).assign( schema=get_schema, response=lambda x: db.run(x["query"]), ) | prompt_response | model ) message = full_chain.invoke({"question": "How many employees are there?"}) print(f"message: {message}")

运行结果

? python3 test09.py message: content='There are a total of 8 employees in the database.' response_metadata={'finish_reason': 'stop', 'logprobs': None}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/1125534.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Python高效计算斐波那契数列

实现功能&#xff1a;计算斐波那契数列的第n项以下是用 Python 编写的递归方法实现斐波那契数列&#xff1a;def fibonacci(n):if n < 0:return "输入必须为正整数"elif n 1:return 0elif n 2:return 1else:return fibonacci(n - 1) fibonacci(n - 2)# 示例调用…

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 的域将…

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

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

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 lang…

使用dify搭建爬虫Agent工作流

最近用Dify做了一个工作流应用&#xff0c;可以实现自动化采集亚马逊商品信息&#xff0c;包括名称、价格、折扣、评分、评论等关键字段&#xff0c;然后使用DeepSeek对商品竞争力、价格、用户口碑进行分析&#xff0c;为跨境卖家提供一份完整的分析报告。 整个工作流搭建用到了…

【课程设计/毕业设计】基于深度学习机器学习的土豆疾病识别

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

内驱力:点燃自我成长的发动机

你是否曾有过这样的经历:被外在压力推着走时倍感疲惫,而发自内心想要做一件事时却充满能量?这背后起作用的就是内驱力——那个无需外力推动、却能让每个人持续前进的内心发动机。 内驱力是什么? 内驱力是一种源自内心的动力,它让我们主动追求成长、学习和进步。与外部的…

Katalon平台的集成生态

在现代软件开发中&#xff0c;任何工具都难以孤立地发挥作用。一个工具的价值&#xff0c;往往与其融入现有技术生态的能力息息相关。Katalon平台深谙此道&#xff0c;构建了一个极其广泛的集成网络&#xff0c;使其不仅能作为强大的自动化测试工具独立运作&#xff0c;更能成为…

Python代码实现示例解析

代码实现 以下是一个实现[输入代码要求]的[输入编程语言]代码示例&#xff1a; def example_function(input_data):"""示例函数&#xff1a;实现[输入代码要求]参数&#xff1a;input_data: 输入数据返回&#xff1a;处理后的结果"""# 初始化结…

深度学习毕设项目:基于python深度学习的苹果和西红柿识别

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

新手进阶Python:给办公助手加定时功能,自动处理任务不用盯

大家好&#xff01;我是CSDN的Python新手博主&#xff5e; 上一篇我们整合了Excel、Word、PDF、OCR的全能办公助手&#xff0c;很多小伙伴反馈“如果能定时自动运行就好了&#xff0c;比如每天早上8点自动处理Excel数据、生成报表并发送给领导&#xff0c;不用我手动点”。今天…

FastAPI 极简教程1

FastAPI 极简教程 文章目录 FastAPI 极简教程 一 环境准备与安装 二 最小可用示例 三 核心概念速览 **四 项目结构与路由拆分** 五 运行与部署要点 🚀 FastAPI 极简教程 (10-50行代码) 0️⃣ 1分钟搞定 步骤 一 环境准备与安装 使用 Python 3.8+,建议搭配虚拟环境(venv)隔…

计及电转气协同的含碳捕集与垃圾焚烧虚拟电厂优化调度Matlab代码

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。&#x1f34e; 往期回顾关注个人主页&#xff1a;Matlab科研工作室&#x1f447; 关注我领取海量matlab电子书和数学建模资料 &#x1f34…

数据科学为大数据领域的业务增长赋能

数据科学为大数据领域的业务增长赋能 关键词:数据科学、大数据、业务增长、机器学习、数据分析、数据挖掘、商业智能 摘要:本文探讨了数据科学如何在大数据时代为企业业务增长提供强大动力。我们将从基础概念入手,分析数据科学的核心技术栈,展示实际应用案例,并展望未来发…

深度学习毕设选题推荐:python基于CNN卷积神经网络对猫狗数据集训练识别

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

精准编程代码生成指南

请提供具体的编程语言和代码要求&#xff0c;以便生成符合需求的代码片段。例如&#xff1a;编程语言&#xff1a;Python代码要求&#xff1a;实现一个函数&#xff0c;计算两个数的和示例格式如下&#xff1a;编程语言Python代码要求实现一个函数&#xff0c;计算两个数的和代…

基于阶梯碳交易的含P2G-CCS耦合和燃气掺氢的虚拟电厂优化调度Matlab代码

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。&#x1f34e; 往期回顾关注个人主页&#xff1a;Matlab科研工作室&#x1f447; 关注我领取海量matlab电子书和数学建模资料 &#x1f34…

什么是LLDP

文章目录为什么需要LLDPLLDP应用场景有哪些LLDP报文格式LLDP是如何工作的LLDP&#xff08;Link Layer Discovery Protocol&#xff09;是IEEE 802.1ab中定义的链路层发现协议。LLDP是一种标准的二层发现方式&#xff0c;可以将本端设备的管理地址、设备标识、接口标识等信息组织…

深度学习毕设选题推荐:基于python-cnn深度学习的猫的种类识别基于人工智能-cnn深度学习的猫的种类识别

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

华为OD技术面真题 - 计算机网络 - 1

文章目录计算机网络体系计算机网络为什么要分层应用进程的数据在各层之间传递过程端口、IP地址和MAC地址分别的作用说说不同层经典网络协议计算机网络体系 计算机网络体系结构标准主要分为三种: OSI体系结构:概念清楚&#xff0c;理论也比较完整&#xff0c;但是它既复杂又不…