当前位置: 首页 > news >正文

基于 Doris + LangChain 的 AI 助手升级:Embedding + BM25 混合检索改造

一、为什么要做这次改造?

在之前的[《基于Doris+LangChain构建数据智能运营AI助手》]项目中,知识库检索采用的是典型的Embedding向量检索方案。

整体流程如下:

用户问题 ↓Embedding 向量化 ↓Doris 向量检索 ↓TopK知识召回 ↓LLM生成答案

这种方案能够很好地解决语义理解问题,但随着知识库规模不断扩大,我们逐渐发现,仅依赖向量检索并不能覆盖所有场景。

问题一:专业术语召回不稳定

在企业知识库中,经常会出现大量业务术语:

GMV支付转化率风控拒贷率授信通过率

这类问题往往要求精确匹配,而Embedding更擅长理解语义,对于专业名词、缩写词、指标编码的匹配能力相对有限。

问题二:表名、字段名检索效果较差

例如用户查询:

ods_user_login_dirisk_control_scoreloan_apply_cnt

这些内容本质上属于:

表名字段名指标编码枚举值

对于这种精确关键词场景,向量检索的优势并不明显。

问题三:单一路径检索存在天然盲区

检索方式优势
Embedding语义理解能力强,能够发现表达不同但含义相近的内容
BM25关键词匹配能力强,适合术语、指标名、表名、字段名等精确检索场景

二者解决的是不同类型的问题,如果仅依赖其中一种检索方式,都会出现召回盲区。

因此,我们希望同时利用Embedding的语义理解能力以及BM25的关键词匹配能力,构建一套更加稳定的混合检索方案。

二、改造目标

本次升级的核心目标:引入BM25关键词检索,与现有Embedding检索形成双路召回,通过融合排序提升知识库召回准确率。

最终实现:

✅ 提升专业术语召回能力

✅ 提升表名、字段名匹配能力

✅ 降低漏召率

✅ 提高大模型最终回答准确率

三、整体方案设计

本次改造采用业内主流的Hybrid Search(混合检索) 方案。

整体思路如下:

  1. 用户问题同时进入两条检索链路
  2. Embedding检索负责语义召回
  3. BM25检索负责关键词召回
  4. 双路结果通过RRF(Reciprocal Rank Fusion)融合排序
  5. 返回最终Top3结果供大模型生成答案

整体架构如下:

四、检索流程详解

五、核心代码实现

修改search_metric_definitions方法,新增_rrf_fusion方法:

def search_metric_definitions(self, query, types="document", kw="metric"): """搜索相关指标定义 / 表字段信息 — 混合检索版本""" if types == "document": ifnot self.vector_store: return ["未找到相关指标定义"] # === 1. Embedding检索 === query_vec = TextEmbedding.call( model=TextEmbedding.Models.text_embedding_v3, input=query, dimension=512 ).output['embeddings'][0]['embedding'] auth = AuthOptions( host=DORIS_CONFIG["host"], query_port=DORIS_CONFIG["port"], user=DORIS_CONFIG["user"], password="" ) client = DorisVectorClient(database=DORIS_CONFIG["database"], auth_options=auth) table = client.open_table("doris_vector_table") embedding_results = table.search(query_vec, metric_type="l2_distance").limit(10).select(["content"]).to_list() # === 2. BM25检索 === corpus = [row[1] for row in self.vector_store] tokenized_corpus = [list(jieba.cut(doc)) for doc in corpus] bm25 = BM25Okapi(tokenized_corpus) tokenized_query = list(jieba.cut(query)) bm25_scores = bm25.get_scores(tokenized_query) top_bm25_indices = sorted( range(len(bm25_scores)), key=lambda i: bm25_scores[i], reverse=True )[:10] bm25_results = [{"content": corpus[i]} for i in top_bm25_indices if bm25_scores[i] > 0] # === 3. RRF融合 === return self._rrf_fusion(embedding_results, bm25_results, top_k=3) elif types == "table": return search_by_table(kw.strip()) elif types == "column": return search_by_column(kw.strip()) else: return ["未找到相关指标定义"]def _rrf_fusion(self, embedding_results, bm25_results, top_k=3, k=60): """Reciprocal Rank Fusion 融合两路检索结果""" scores = {} for rank, item in enumerate(embedding_results): content = item["content"] if isinstance(item, dict) else str(item) scores[content] = scores.get(content, 0) + 1.0 / (k + rank + 1) for rank, item in enumerate(bm25_results): content = item["content"] if isinstance(item, dict) else str(item) scores[content] = scores.get(content, 0) + 1.0 / (k + rank + 1) sorted_results = sorted(scores.items(), key=lambda x: x[1], reverse=True) return [{"content": content} for content, _ in sorted_results[:top_k]]

学AI大模型的正确顺序,千万不要搞错了

🤔2026年AI风口已来!各行各业的AI渗透肉眼可见,超多公司要么转型做AI相关产品,要么高薪挖AI技术人才,机遇直接摆在眼前!

有往AI方向发展,或者本身有后端编程基础的朋友,直接冲AI大模型应用开发转岗超合适!

就算暂时不打算转岗,了解大模型、RAG、Prompt、Agent这些热门概念,能上手做简单项目,也绝对是求职加分王🔋

📝给大家整理了超全最新的AI大模型应用开发学习清单和资料,手把手帮你快速入门!👇👇

学习路线:

✅大模型基础认知—大模型核心原理、发展历程、主流模型(GPT、文心一言等)特点解析
✅核心技术模块—RAG检索增强生成、Prompt工程实战、Agent智能体开发逻辑
✅开发基础能力—Python进阶、API接口调用、大模型开发框架(LangChain等)实操
✅应用场景开发—智能问答系统、企业知识库、AIGC内容生成工具、行业定制化大模型应用
✅项目落地流程—需求拆解、技术选型、模型调优、测试上线、运维迭代
✅面试求职冲刺—岗位JD解析、简历AI项目包装、高频面试题汇总、模拟面经

以上6大模块,看似清晰好上手,实则每个部分都有扎实的核心内容需要吃透!

我把大模型的学习全流程已经整理📚好了!抓住AI时代风口,轻松解锁职业新可能,希望大家都能把握机遇,实现薪资/职业跃迁~

这份完整版的大模型 AI 学习资料已经上传CSDN,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费

http://www.jsqmd.com/news/1112689/

相关文章:

  • 3步掌握Fofa Viewer:网络安全资产探测的高效JavaFX客户端
  • 科技融匠心!康姿百德学生床垫筑牢成长睡眠防线
  • AI对话录2026/7/2-避风港尚未命名
  • Android 7系统日志(七)实战调试与常见问题分析
  • 多维聚合中的数据操纵:维度对齐、层级补全与稀疏填充实战
  • GetQzonehistory:如何一键找回QQ空间消失的青春记忆
  • python-langchain框架(3-22-Conversational_ReAct智能体)
  • 周报总被退回重写?ChatGPT智能日报模板实战手册,含领导关注点自动匹配算法
  • AI项目标题规范:如何写出可验证、可落地的技术博文
  • Java毕设项目:基于 SpringBoot 的河湖水务智能监测与应急调度系统的设计与实现 基于 SpringBoot 的水务应急预警与资源调度管理系统 (源码+文档,讲解、调试运行,定制等)
  • 7.8k Star!R2R:让 RAG 从 Demo 直达生产的开源引擎
  • 2026年AI简历工具深度横评:鹅来面 vs 知叶简历 vs TalenCat CV,三款主流工具实测报告
  • Spring Boot实现百万级数据统计与Excel导出优化
  • 机器学习驱动的应用性能预测实战指南
  • HAL_CAN
  • 图像分类入门:CNN原理与Python实战指南
  • web安全代码基础-PHP(代码/命令执行安全)
  • 边缘计算中DNN模型保护的ConvShatter技术解析
  • 本地部署AI Agent,6G显存跑Qwen3.6-35B-A3B 从入门到实战全流程
  • Oracle EBS配置器未授权访问漏洞(CVE-2025-61884)深度剖析与防护实践
  • 终极B站视频下载指南:解锁大会员4K和充电专属内容
  • 《开心消消乐》为什么能成为国民级三消游戏
  • MST6M182XST 行业应用方案 · 从液晶电视到商显
  • OpenClaw与QQ Bot集成开发指南
  • Java基础语法深度复盘+算法竞赛核心技能
  • 我为能准时下班而做的准备,以及由此的收获,同时总结下不足
  • KWM转MP3:从酷我加密容器到通用格式,5种技术方案完全解析
  • Java 大鱼吃小鱼项目整体分包与类结构分析
  • AppleRa1n终极指南:5分钟快速绕过iOS 15-16激活锁
  • 2026不花百万到纳米级:国产轮廓仪精度实测