前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >知识图谱构建系统 毕业设计 JAVA+Vue+SpringBoot+MySQL

知识图谱构建系统 毕业设计 JAVA+Vue+SpringBoot+MySQL

作者头像
Designer 小郑
发布2024-02-22 10:29:11
3340
发布2024-02-22 10:29:11
举报
文章被收录于专栏:跟着小郑学JAVA

作者主页Designer 小郑 作者简介:3年JAVA全栈开发经验,专注JAVA技术、系统定制、远程指导,致力于企业数字化转型,CSDN博客专家,阿里云社区专家博主,蓝桥云课讲师。

\color{red}{本文项目编号:S093。}

一、摘要

1.1 项目介绍

基于JAVA+Vue+SpringBoot+MySQL的知识图谱构建系统,包含了知识图谱模块、知识点模块、学生测评模块、学生成绩模块,还包含系统自带的用户管理、部门管理、角色管理、菜单管理、日志管理、数据字典管理、文件管理、图表展示等基础模块,知识图谱构建系统基于角色的访问控制,给教师、学生使用,可将权限精确到按钮级别,您可以自定义角色并分配权限,系统适合设计精确的权限约束需求。

1.2 项目录屏


二、功能模块

2.1 知识图谱模块

知识图谱构建系统的知识图谱模块是系统中的核心组件,它负责存储和管理知识图谱中的数据。具体来说,增加功能允许用户向知识图谱中添加新的实体、关系和属性,通过定义实体的类型和属性,以及它们之间的关系,可以逐步构建起一个丰富的知识图谱。用户可以利用删除功能从知识图谱中删除指定的实体、关系或属性,这使得系统能够修正错误的数据或者清理不再需要的信息,确保知识图谱的准确性和完整性。

知识图谱模块允许用户对知识图谱中的实体、关系或属性进行修改,例如可以更新实体的属性值或者调整关系的权重,从而保持知识图谱与实际情况的一致性。查询功能使用户能够根据指定的条件从知识图谱中检索相关的实体、关系或属性,查询功能可以支持基本的关键字搜索,也可以支持更复杂的图形查询,例如关系路径查询或图谱推理,帮助用户快速获取所需信息。知识图谱模块实现了对知识图谱的灵活管理和查询,为用户提供丰富的知识服务。同时,针对不同的应用场景和业务需求,可以定制化知识图谱模块的功能,以满足特定需求。

2.2 知识点模块

知识图谱构建系统的知识点模块是一个重要的组成部分,它负责管理和操作知识图谱中的知识点,增加功能允许用户向知识图谱中添加新的知识点,用户可以定义知识点的类型、属性和关联关系,并将其添加到知识图谱中。通过这个功能,用户可以逐步丰富知识图谱,增加新的知识点。用户可以利用删除功能从知识图谱中删除指定的知识点,这可以用于修正错误的数据或者清理不再需要的信息。删除知识点时,系统会相应地更新与该知识点相关的关系。

知识点模块允许用户对知识图谱中的知识点进行修改,用户可以更新知识点的属性值,调整关系的权重或属性。这样可以确保知识图谱中的信息与实际情况保持一致。查询功能使用户能够根据指定的条件从知识图谱中检索相关的知识点,用户可以使用关键字搜索、属性过滤或者复杂的查询语句来获取所需的知识点。查询功能可以帮助用户快速找到特定的知识点,进行相关分析或提供相关推荐。知识点模块实现了对知识图谱中知识点的管理和操作。它使得用户能够方便地增加、删除、修改和查询知识点,从而构建和维护一个丰富的知识图谱。同时,该模块还可以根据具体应用的需求进行扩展和定制,以满足不同场景下的知识管理需求。

2.3 学生测评模块

知识图谱构建系统的学生测评模块是系统中的一个功能模块,它用于管理和处理学生的测评数据,增加功能允许教师或管理员向系统中添加学生的测评数据。这些数据可以包括学生的成绩、考试得分、作业完成情况等。通过这个功能,可以将学生的测评数据与其在知识图谱中的相关知识点连接起来。用户可以利用删除功能从系统中删除学生的测评数据。这可以用于清理错误数据或者移除不再需要的测评信息。删除数据时,系统会相应地更新与该学生测评数据相关的知识点和统计信息。

学生测评模块允许用户对学生的测评数据进行修改。例如,可以更新学生的成绩或者修改作业得分。这样可以确保学生测评数据的准确性和完整性。查询功能使用户能够根据指定的条件从系统中检索学生的测评数据。用户可以根据学生的姓名、学号或其他关键字进行查询。查询功能还可以支持按照时间范围、学科分类等进行过滤,以便快速找到所需的测评数据。学生测评模块实现了对学生测评数据的管理和操作。教师和管理员可以方便地增加、删除、修改和查询学生的测评数据,从而对学生的学习情况进行评估和分析。同时,该模块还可以根据具体应用的需求进行扩展和定制,以满足不同场景下的学生测评需求。

2.4 学生成绩模块

知识图谱构建系统的学生成绩模块是系统中的一个重要组成部分,它用于管理和处理学生的成绩数据,增加功能允许教师或管理员将学生的成绩数据添加到系统中,可以添加学生的考试成绩、作业成绩等。通过这个功能,可以将学生成绩与其在知识图谱中的相关知识点连接起来,帮助教师和管理员更好地评估学生的学习情况。用户可以利用删除功能从系统中删除学生的成绩数据,这可以用于清理错误数据或者移除不再需要的成绩信息。删除数据时,系统会相应地更新与该学生成绩数据相关的知识点和统计信息。

学生成绩模块允许用户对学生的成绩数据进行修改,例如可以更新学生的考试成绩或者修改作业得分。这样可以确保学生成绩数据的准确性和完整性。查询该功能使用户能够根据指定的条件从系统中检索学生的成绩数据,用户可以根据学生的姓名、学号或其他关键字进行查询。查询功能还可以支持按照时间范围、学科分类等进行过滤,学生成绩模块实现了对学生成绩数据的管理和操作。教师和管理员可以方便地增加、删除、修改和查询学生的成绩数据,从而对学生的学习情况进行评估和分析。同时,该模块还可以根据具体应用的需求进行扩展和定制,以满足不同场景下的学生成绩管理需求。

三、系统展示


四、核心代码

4.1 查询知识点

代码语言:javascript
复制
@RequestMapping(value = "/getByPage", method = RequestMethod.GET)
@ApiOperation(value = "查询知识点")
public Result<IPage<Knowledge>> getByPage(@ModelAttribute Knowledge knowledge ,@ModelAttribute PageVo page){
    QueryWrapper<Knowledge> qw = new QueryWrapper<>();
    if(!ZwzNullUtils.isNull(knowledge.getGraphId())) {
        qw.eq("graph_id",knowledge.getGraphId());
    }
    if(!ZwzNullUtils.isNull(knowledge.getTitle())) {
        qw.like("title",knowledge.getTitle());
    }
    IPage<Knowledge> data = iKnowledgeService.page(PageUtil.initMpPage(page),qw);
    return new ResultUtil<IPage<Knowledge>>().setData(data);
}

4.2 新增知识点

代码语言:javascript
复制
@RequestMapping(value = "/insert", method = RequestMethod.POST)
@ApiOperation(value = "新增知识点")
public Result<Knowledge> insert(Knowledge knowledge){
    if(ZwzNullUtils.isNull(knowledge.getGraphId())) {
        return ResultUtil.error("知识图谱不能为空");
    }
    KnowledgeGraph graph = iKnowledgeGraphService.getById(knowledge.getGraphId());
    if(graph == null) {
        return ResultUtil.error("知识图谱不存在");
    }
    knowledge.setGraphName(graph.getTitle());
    iKnowledgeService.saveOrUpdate(knowledge);
    return new ResultUtil<Knowledge>().setData(knowledge);
}

4.3 查询知识图谱

代码语言:javascript
复制
@RequestMapping(value = "/getByPage", method = RequestMethod.GET)
@ApiOperation(value = "查询知识图谱")
public Result<IPage<KnowledgeGraph>> getByPage(@ModelAttribute KnowledgeGraph knowledgeGraph ,@ModelAttribute PageVo page){
    QueryWrapper<KnowledgeGraph> qw = new QueryWrapper<>();
    if(!ZwzNullUtils.isNull(knowledgeGraph.getTitle())) {
        qw.like("title",knowledgeGraph.getTitle());
    }
    if(!ZwzNullUtils.isNull(knowledgeGraph.getType())) {
        qw.eq("type",knowledgeGraph.getType());
    }
    IPage<KnowledgeGraph> data = iKnowledgeGraphService.page(PageUtil.initMpPage(page),qw);
    return new ResultUtil<IPage<KnowledgeGraph>>().setData(data);
}

4.4 查询学生成绩

代码语言:javascript
复制
@RequestMapping(value = "/addPaperGrade", method = RequestMethod.GET)
@ApiOperation(value = "查询学生成绩")
public Result<Object> get(@RequestParam float grade){
    User currUser = securityUtil.getCurrUser();
    StudentAchievement sa = new StudentAchievement();
    sa.setStudentId(currUser.getId());
    sa.setStudentName(currUser.getNickname());
    sa.setTitle(DateUtil.now() + "的学生测评");
    sa.setValue(BigDecimal.valueOf(grade));
    sa.setComment("自动计算分数");
    iStudentAchievementService.saveOrUpdate(sa);
    return ResultUtil.success();
}

4.5 查询学生成绩

代码语言:javascript
复制
@RequestMapping(value = "/getByMyPage", method = RequestMethod.GET)
@ApiOperation(value = "查询学生成绩")
public Result<IPage<StudentAchievement>> getByMyPage(@ModelAttribute StudentAchievement studentAchievement ,@ModelAttribute PageVo page){
    QueryWrapper<StudentAchievement> qw = new QueryWrapper<>();
    if(!ZwzNullUtils.isNull(studentAchievement.getTitle())) {
        qw.like("title",studentAchievement.getTitle());
    }
    qw.eq("student_id",securityUtil.getCurrUser().getId());
    IPage<StudentAchievement> data = iStudentAchievementService.page(PageUtil.initMpPage(page),qw);
    return new ResultUtil<IPage<StudentAchievement>>().setData(data);
}

五、免责说明

  • 本项目仅供个人学习使用,商用授权请联系博主,否则后果自负。
  • 博主拥有本软件构建后的应用系统全部内容所有权及独立的知识产权,拥有最终解释权。
  • 如有问题,欢迎在仓库 Issue 留言,看到后会第一时间回复,相关意见会酌情考虑,但没有一定被采纳的承诺或保证。

下载本系统代码或使用本系统的用户,必须同意以下内容,否则请勿下载!

  1. 出于自愿而使用/开发本软件,了解使用本软件的风险,且同意自己承担使用本软件的风险。
  2. 利用本软件构建的网站的任何信息内容以及导致的任何版权纠纷和法律争议及后果和博主无关,博主对此不承担任何责任。
  3. 在任何情况下,对于因使用或无法使用本软件而导致的任何难以合理预估的损失(包括但不仅限于商业利润损失、业务中断与业务信息丢失),博主概不承担任何责任。
  4. 必须了解使用本软件的风险,博主不承诺提供一对一的技术支持、使用担保,也不承担任何因本软件而产生的难以预料的问题的相关责任。
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2024-02-21,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、摘要
    • 1.1 项目介绍
      • 1.2 项目录屏
      • 二、功能模块
        • 2.1 知识图谱模块
          • 2.2 知识点模块
            • 2.3 学生测评模块
              • 2.4 学生成绩模块
              • 三、系统展示
              • 四、核心代码
                • 4.1 查询知识点
                  • 4.2 新增知识点
                    • 4.3 查询知识图谱
                      • 4.4 查询学生成绩
                        • 4.5 查询学生成绩
                        • 五、免责说明
                        相关产品与服务
                        云数据库 MySQL
                        腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
                        领券
                        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档