前端实现:React + Neo4j构建图数据检索

用 React + Neo4j 构建实时推荐系统

🔥 为什么选择图数据库做推荐系统?

在现代推荐系统中,用户行为、兴趣标签、社交关系和商品信息往往存在复杂的关联关系,传统关系型数据库通过多表联查来完成推荐逻辑,但面对海量数据 + 实时推荐的需求,性能往往无法满足。

图数据库(Graph Database)天然适合表示和查询这种复杂的关系网络,可以用更少的代码实现更高效的推荐系统。


1. 技术选型

层级 技术 说明
前端 React 展示推荐结果
数据存储 Neo4j 存储用户、商品、关系网络
数据查询 Cypher 图数据库查询语言
后端服务 Node.js 作为 API 中转层
图数据库驱动 neo4j-driver Node.js 官方驱动

2. 数据建模

假设我们做一个电影推荐系统,数据模型如下:

  • 用户(User)
  • 电影(Movie)
  • 类型(Genre)
  • 喜欢关系(LIKE)
  • 属于类型关系(BELONGS_TO)

图模型结构大致如下:

scss 复制代码
(Alice)-[:LIKE]->(Inception)-[:BELONGS_TO]->(Sci-Fi)
(Bob)-[:LIKE]->(Interstellar)-[:BELONGS_TO]->(Sci-Fi)

推荐规则:

  1. 查询用户喜欢的电影类型
  2. 找出喜欢相同类型电影的其他用户
  3. 推荐这些用户喜欢但自己还没看的电影

3. Neo4j 安装与配置

Docker 方式安装
bash 复制代码
docker run -d --name neo4j -p 7474:7474 -p 7687:7687 \
-e NEO4J_AUTH=neo4j/password neo4j

打开 http://localhost:7474 进行管理配置。


4. Neo4j 数据初始化

通过 Cypher 语句插入测试数据:

cypher 复制代码
CREATE (:User {name: 'Alice'})
CREATE (:User {name: 'Bob'})
CREATE (:Movie {title: 'Inception'})
CREATE (:Movie {title: 'Interstellar'})
CREATE (:Genre {name: 'Sci-Fi'})
MATCH (m:Movie {title: 'Inception'}), (g:Genre {name: 'Sci-Fi'}) CREATE (m)-[:BELONGS_TO]->(g)
MATCH (u:User {name: 'Alice'}), (m:Movie {title: 'Inception'}) CREATE (u)-[:LIKE]->(m)

5. Node.js API 构建

安装 Neo4j 驱动:

bash 复制代码
npm install neo4j-driver express cors

创建 API 服务:

js 复制代码
const express = require('express');
const neo4j = require('neo4j-driver');
const app = express();
const driver = neo4j.driver('bolt://localhost:7687', neo4j.auth.basic('neo4j', 'password'));

app.get('/recommend/:username', async (req, res) => {
  const session = driver.session();
  const { username } = req.params;

  const result = await session.run(`
    MATCH (u:User {name: $username})-[:LIKE]->(:Movie)-[:BELONGS_TO]->(g:Genre)
    MATCH (other:User)-[:LIKE]->(m:Movie)-[:BELONGS_TO]->(g)
    WHERE other <> u AND NOT (u)-[:LIKE]->(m)
    RETURN DISTINCT m.title AS recommendation
  `, { username });

  res.json(result.records.map(record => record.get('recommendation')));
  session.close();
});

app.listen(3001, () => console.log('API running on port 3001'));

6. React 前端页面开发

安装 Axios:

bash 复制代码
npm install axios

创建组件:

jsx 复制代码
import { useEffect, useState } from 'react';
import axios from 'axios';

export default function Recommendation({ username }) {
  const [movies, setMovies] = useState([]);

  useEffect(() => {
    axios.get(`http://localhost:3001/recommend/${username}`)
      .then(response => setMovies(response.data));
  }, [username]);

  return (
    <div>
      <h3>为 {username} 推荐的电影:</h3>
      <ul>
        {movies.map(movie => <li key={movie}>{movie}</li>)}
      </ul>
    </div>
  );
}

7. 启动项目

  1. 启动 Neo4j
  2. 启动 Node.js API 服务
  3. 启动 React 应用

🎯 测试结果

假设 Alice 喜欢《Inception》,Bob 喜欢《Interstellar》。

查询接口:

bash 复制代码
http://localhost:3001/recommend/Alice

✅ 输出:

css 复制代码
["Interstellar"]

总结

系统特性 传统关系型 图数据库
查询效率
数据建模 不直观 贴近业务关系
关联数据 难拓展 天然支持
实时推荐

🚀 最后总结

  • Neo4j + React 可以轻松搭建一个高效、实时的推荐系统。
  • 图数据库对数据关系查询的性能优势非常明显。
  • 代码量少,逻辑清晰,天然适合社交、推荐、金融等领域。

相关推荐
东锋1.32 分钟前
前端动画库 Anime.js 的V4 版本,兼容 Vue、React
前端·javascript·vue.js
满怀101515 分钟前
【Flask全栈开发指南】从零构建企业级Web应用
前端·python·flask·后端开发·全栈开发
小杨升级打怪中42 分钟前
前端面经-webpack篇--定义、配置、构建流程、 Loader、Tree Shaking、懒加载与预加载、代码分割、 Plugin 机制
前端·webpack·node.js
Yvonne爱编码1 小时前
CSS- 4.4 固定定位(fixed)& 咖啡售卖官网实例
前端·css·html·状态模式·hbuilder
SuperherRo1 小时前
Web开发-JavaEE应用&SpringBoot栈&SnakeYaml反序列化链&JAR&WAR&构建打包
前端·java-ee·jar·反序列化·war·snakeyaml
大帅不是我1 小时前
Python多进程编程执行任务
java·前端·python
前端怎么个事1 小时前
框架的源码理解——V3中的ref和reactive
前端·javascript·vue.js
Ciito1 小时前
将 Element UI 表格元素导出为 Excel 文件(处理了多级表头和固定列导出的问题)
前端·vue.js·elementui·excel
不爱吃饭爱吃菜2 小时前
uniapp微信小程序一键授权登录
前端·javascript·vue.js·微信小程序·uni-app
90后小陈老师3 小时前
3D个人简历网站 5.天空、鸟、飞机
前端·javascript·3d