news 2026/6/25 14:06:48

一篇文章如何入库的

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
一篇文章如何入库的
  1. 从文章里抽实体(人、公司、地点、产品、时间…)
  2. 抽实体之间的关系(A 工作于 B、C 位于 D、E 认识 F…)
  3. 生成节点 + 关系(Node + Relationship)
  4. 批量写入 Neo4j(CREATE / MERGE)

最终在 Neo4j 里形成一张知识图谱,RAG 检索时就可以沿着关系查上下文。

我们用一段超短新闻做演示:

张三在2023年加入了字节跳动,担任算法工程师。 李四是张三的同事,他们都在北京工作。

以上的超短新闻,要想配合入图数据库,首先是需要抽象出以下信息。

实体(Nodes)

  • 张三 (Person)
  • 李四 (Person)
  • 字节跳动 (Company)
  • 北京 (Location)

关系(Relationships)

  • 张三 ——WORKS_AT——> 字节跳动
  • 张三 ——COLLEAGUE_OF——> 李四
  • 张三 ——WORKS_IN——> 北京
  • 李四 ——WORKS_IN——> 北京

属性

  • 张三:age=None, job=算法工程师, join_year=2023

实体,关系,属性信息都确认了之后,就可以通过以下语句入库了。

// 创建节点 MERGE (p1:Person {name:"张三"}) SET p1.job="算法工程师", p1.join_year=2023 MERGE (p2:Person {name:"李四"}) MERGE (c:Company {name:"字节跳动"}) MERGE (l:Location {name:"北京"}) // 创建关系 MERGE (p1)-[:WORKS_AT]->(c) MERGE (p1)-[:COLLEAGUE_OF]->(p2) MERGE (p1)-[:WORKS_IN]->(l) MERGE (p2)-[:WORKS_IN]->(l)

为什么用 MERGE 不用 CREATE?

  • CREATE:重复执行会重复创建节点
  • MERGE:不存在则创建,存在则更新 →Graph RAG 标准写法

那么如何把文章里的信息是如何抽象出的实体和关系呢,直接说过程:文章不是人工转的,是 LLM 自动转的!

下面是真实工程化流程

首先,给大模型的提示词

你是知识图谱抽取专家。请从文本中抽取: 1. 实体(类型:Person, Company, Location, Organization) 2. 关系(只能用:WORKS_AT, COLLEAGUE_OF, WORKS_IN, FOUNDER_OF) 输出格式严格JSON: { "nodes": [{"label":"Person", "name":"张三", "attributes":{"job":"算法工程师"}}], "relations": [{"from":"张三", "to":"字节跳动", "type":"WORKS_AT"}] } 文本: 张三在2023年加入了字节跳动,担任算法工程师。李四是张三的同事,他们都在北京工作。

以上提示词可以放在任何工具里测试,包括龙虾,豆包等。

实体和关系总结出来了,可以看到结果如下:

{ "nodes": [ {"label":"Person","name":"张三","attributes":{"job":"算法工程师","join_year":2023}}, {"label":"Person","name":"李四","attributes":{}}, {"label":"Company","name":"字节跳动","attributes":{}}, {"label":"Location","name":"北京","attributes":{}} ], "relations": [ {"from":"张三","to":"字节跳动","type":"WORKS_AT"}, {"from":"张三","to":"李四","type":"COLLEAGUE_OF"}, {"from":"张三","to":"北京","type":"WORKS_IN"}, {"from":"李四","to":"北京","type":"WORKS_IN"} ] }

注:如果模型是在线API,那么基本上都能按照要求做出指定的输出,如果是本地部署的模型,参数量比较低的话,输出可能会走样。

最后,通过python代码自动把 JSON 转成 Cypher 写入 Neo4j

from neo4j import GraphDatabase # 连接 Neo4j uri = "bolt://localhost:7687" user = "neo4j" password = "your-password" driver = GraphDatabase.driver(uri, auth=(user, password)) # 从LLM拿到的知识图谱数据 data = { ...上面的JSON... } # 写入节点 for node in data["nodes"]: if node["attributes"]: attrs = ", ".join([f"{k}: '{v}'" for k, v in node["attributes"].items()]) cypher = f"MERGE (n:{node['label']} {{name:'{node['name']}', {attrs}}})" else: cypher = f"MERGE (n:{node['label']} {{name:'{node['name']}'}})" driver.session().run(cypher) # 写入关系 for rel in data["relations"]: cypher = f""" MATCH (a {{name:'{rel['from']}'}}), (b {{name:'{rel['to']}'}}) MERGE (a)-[:{rel['type']}]->(b) """ driver.session().run(cypher)

运行完,一篇文章就变成知识图谱了!


最终效果(Neo4j 里看到的图)
你会看到:

  • 张三、李四、字节跳动、北京
  • 它们之间用箭头连起来
  • Graph RAG 检索时就能沿着关系推理

最后再说一种更简单粗暴的方法,跳过大模型生成JSON和python的JSON遍历,直接让大模型生成语句。

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

5步掌握iOS激活锁绕过:applera1n完整实践指南

5步掌握iOS激活锁绕过:applera1n完整实践指南 【免费下载链接】applera1n icloud bypass for ios 15-16 项目地址: https://gitcode.com/gh_mirrors/ap/applera1n 对于iOS设备用户而言,激活锁(Activation Lock)是一项重要的…

作者头像 李华
网站建设 2026/6/25 14:05:57

SqlToy Navigator 插件介绍

SqlToy Navigator 插件介绍 插件定位 SqlToy Navigator 是一款面向 SqlToy ORM 项目的 IntelliJ IDEA 插件,用于提升 Java 代码与 XML SQL 定义之间的导航、阅读和维护效率。 插件核心解决的问题是:在 SqlToy 项目中,Java 代码通常通过字符串…

作者头像 李华
网站建设 2026/6/25 14:04:59

桌牌批量生成工具使用教程,免安装座位牌打印程序下载

上周被老板叫去做会议桌牌,200多个名字要一个一个手敲。说实话,那种复制粘贴到眼花的绝望,做过的人都懂。后来同事给我推了个小工具,不用装,解压就能跑。批量导入才是核心这工具最实用的地方是能识别Excel多列数据。把…

作者头像 李华
网站建设 2026/6/25 14:03:05

Genie 3世界模型:从AI生成到可交互物理模拟的范式跃迁

1. 这不是视频生成器,而是一扇通往可交互数字世界的门你有没有试过对着一张风景照发呆,心里想着“要是能走进去走一圈该多好”?或者在设计一个游戏关卡时,反复调整3D建模软件里的地形参数,花掉一整个下午却只改出几棵树…

作者头像 李华
网站建设 2026/6/25 14:02:38

从零学习Kafka:生产者分区机制

分区的核心逻辑 在从零学习Kafka:集群架构和基本概念一文中,我们了解了 Kafka 中分区的概念,它的主要作用一个是支持系统的可伸缩性,另一个是负载均衡。 生产者在写入数据时,实际是要写入到指定的分区。换句话说分区…

作者头像 李华
网站建设 2026/6/25 14:01:16

时间序列预测精度提升实战:校准时间戳与消除信息失真

1. 项目概述:这不是又一篇“LSTM吊打ARIMA”的爽文,而是一份实操中反复撕开、揉碎、再拼好的精度提升手记“Practical Nuances of Time Series Forecasting — Part II— Improving Forecast Accuracy”这个标题里藏着三个关键信号:Practical…

作者头像 李华