26 lines
1.2 KiB
Python
Executable File
26 lines
1.2 KiB
Python
Executable File
from sqlalchemy import Column, Integer, String, DateTime, JSON, func
|
||
|
||
from server.db.base import Base
|
||
|
||
|
||
class ChatHistoryModel(Base):
|
||
"""
|
||
聊天记录模型
|
||
"""
|
||
__tablename__ = 'chat_history'
|
||
# 由前端生成的uuid,如果是自增的话,则需要将id 传给前端,这在流式返回里有点麻烦
|
||
id = Column(String(32), primary_key=True, comment='聊天记录ID')
|
||
# chat/agent_chat等
|
||
chat_type = Column(String(50), comment='聊天类型')
|
||
query = Column(String(4096), comment='用户问题')
|
||
response = Column(String(4096), comment='模型回答')
|
||
# 记录知识库id等,以便后续扩展
|
||
meta_data = Column(JSON, default={})
|
||
# 满分100 越高表示评价越好
|
||
feedback_score = Column(Integer, default=-1, comment='用户评分')
|
||
feedback_reason = Column(String(255), default="", comment='用户评分理由')
|
||
create_time = Column(DateTime, default=func.now(), comment='创建时间')
|
||
|
||
def __repr__(self):
|
||
return f"<ChatHistory(id='{self.id}', chat_type='{self.chat_type}', query='{self.query}', response='{self.response}',meta_data='{self.meta_data}',feedback_score='{self.feedback_score}',feedback_reason='{self.feedback_reason}', create_time='{self.create_time}')>"
|