使用SQLAlchemy和LangChain管理聊天历史:从入门到实战

150 阅读2分钟
# 引言

在现代应用程序开发中,管理和存储聊天历史是一个常见需求。SQLAlchemy是一款强大的ORM工具,结合LangChain库可以高效地实现这一功能。本篇文章将带你了解如何使用SQLAlchemy管理聊天历史,并提供相关代码示例和实用技巧。

## 主要内容

### 什么是SQLAlchemy?

SQLAlchemy是Python语言的开源SQL工具包和对象关系映射器(ORM),可以帮助开发者与数据库交互,支持多种数据库如SQLite、PostgreSQL、MySQL等。

### 使用LangChain管理聊天历史

LangChain库提供了一种灵活的方式来存储和管理聊天消息。`SQLChatMessageHistory`类能够在任何SQLAlchemy支持的数据库中存储聊天记录。为了方便演示,我们将使用SQLite作为示例数据库。

### 环境配置

在使用SQLAlchemy和LangChain之前,我们需要先安装相关包:

```shell
pip install -U langchain-community SQLAlchemy langchain-openai

虽然不是必需,但建议设置LangSmith以获得更好的可观测性。

使用示例

以下代码示例展示了如何使用SQLChatMessageHistory类管理聊天历史:

from langchain_community.chat_message_histories import SQLChatMessageHistory

# 使用API代理服务提高访问稳定性
chat_message_history = SQLChatMessageHistory(
    session_id="test_session", connection_string="sqlite:///sqlite.db"
)

chat_message_history.add_user_message("Hello")
chat_message_history.add_ai_message("Hi")

# 打印存储的消息
print(chat_message_history.messages)  # [HumanMessage(content='Hello'), AIMessage(content='Hi')]

结合LangChain运行链

使用LangChain,可以将聊天历史与AI助手对话结合起来,以下是一个简单的运行链示例:

from langchain_core.prompts import ChatPromptTemplate, MessagesPlaceholder
from langchain_core.runnables.history import RunnableWithMessageHistory
from langchain_openai import ChatOpenAI

prompt = ChatPromptTemplate.from_messages(
    [
        ("system", "You are a helpful assistant."),
        MessagesPlaceholder(variable_name="history"),
        ("human", "{question}"),
    ]
)

chain = prompt | ChatOpenAI()

chain_with_history = RunnableWithMessageHistory(
    chain,
    lambda session_id: SQLChatMessageHistory(
        session_id=session_id, connection_string="sqlite:///sqlite.db"
    ),
    input_messages_key="question",
    history_messages_key="history",
)

# 配置会话ID
config = {"configurable": {"session_id": "<SESSION_ID>"}}

# 模拟聊天
response = chain_with_history.invoke({"question": "Hi! I'm bob"}, config=config)
print(response.content)  # 'Hello Bob! How can I assist you today?'

常见问题和解决方案

  1. 连接失败问题

    • 确保数据库驱动正确安装,对于SQLite无需额外安装,对其他数据库需安装相应的驱动。
  2. 网络访问问题

    • 由于某些地区的网络限制,建议使用API代理服务提高访问稳定性。

总结和进一步学习资源

SQLAlchemy与LangChain的结合提供了一种简单而强大的解决方案来管理聊天历史。希望本文的介绍能够帮助你在实际项目中应用这项技术。你可以进一步学习SQLAlchemy和LangChain的官方文档来深入探索它们的功能。

参考资料

如果这篇文章对你有帮助,欢迎点赞并关注我的博客。您的支持是我持续创作的动力!

---END---