使用 JDBC 连接 Neo4j(头歌)

文章目录

  • 第1关:连接 Neo4j (JDBC)
    • 任务描述
    • 相关知识
      • 完成 JDBC 环境设置
      • 连接 Neo4j 对数据进行查询
    • 编程要求
    • 测试说明
    • 答案
      • 测试前准备
      • 代码文件

第1关:连接 Neo4j (JDBC)

任务描述

本关任务:使用 JDBC 进行 Neo4j 数据库查询。

相关知识

为了完成本关任务,你需要掌握:

  1. 完成 JDBC 环境设置;
  2. 连接 Neo4j 对数据进行查询。

完成 JDBC 环境设置

需要准备的 jar 包有: Neo4j-2.0.1-SNAPSHOT Version; 还有一个是 neo4j 的 lib 文件夹下的 neo4j-kernel-*.jar(* 号为版本号);

将这两个 jar 包导入到所需要的项目中就可以了。

img

jar 包

注意: 这些 jar 包在本实训中已经为大家准备好了,所以大家不用去再添加 jar 包。

连接 Neo4j 对数据进行查询

需要导入的包为:

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
  • 使用 JDBC 驱动连接到 Neo4j :

    Connection con = DriverManager.getConnection("jdbc:neo4j://localhost:7474/","usrname","password");
    

后面的 usernamepassword 需要修改为你的 Neo4j 的用户名和密码。

注意: 实训中的 Neo4j 用户名和密码为:neo4j123456

  • 创建 Statement 进行 CQL 操作:

创建 Statement

Statement stmt = con.createStatement()
  • 使用 stmt 进行增删改查操作:主要使用三个方法进行 executeQuery(查) 和 execute(增、删)、executeUpdate(改); executeQuery

源码解释: ResultSet executeQuery(String sql) throws SQLException;: 主要用于查询数据,需要写入查询语句,进行查询。并且返回值为 ResultSet 结果集,获取数据需要进行循环获取。使用 while 结合 ResultSet.next()使用,使用 getString(String 字段)获取查询的字段数据。 并且需要抛出异常。

// 获取结果集
ResultSet rs = stmt.executeQuery("MATCH (n:Person) RETURN n.name");
// 循环获取数据
while(rs.next()) {System.out.println(rs.getString("n.name"));
}

img

查询结果

红色部分为日志,黑色部分为查询出来的结果集。

boolean execute(String sql) throws SQLException;

可以进行创建和删除节点、关系,返回的为布尔类型的数据,返回 true 表示操作成功,返回 false 表示操作失败。 并且需要抛出异常。 创建节点:

String insertSql = "create (:test {name:'test_2'})";
stmt.execute(insertSql);

img

创建代码

img

创建成功

删除只需要将 Cql 修改为删除语句即可:match (n:test) delete n

int executeUpdate(String sql) throws SQLException;

修改语句为:match (n:test) where n.name="test_2" set n.name="test_1"; 并且需要抛出异常。

使用方法与删除基本一样。

编程要求

根据提示,在右侧编辑器补充代码,查询 movies 数据中,Person 节点中按 name 升序后的,前五个数据的 bornname 两个字段的数据。

注意: 导入 movies数据直接在 Neo4j 界面中输入::play movies,按 Enter 后。会出现一个向导界面,在第二个页面点击一个小播放键即可载入数据。

img

操作流程

测试说明

平台会对你编写的代码进行测试:

测试输入:; 预期输出:(头歌上给出的预期输出是按照出生年升序的,实际如下,应该是按照姓名升序的)

出生年:1961,姓名:Aaron Sorkin
出生年:1940,姓名:Al Pacino
出生年:null,姓名:Angela Scope
出生年:1960,姓名:Annabella Sciorra
出生年:1962,姓名:Anthony Edwards
Unexpected token END_ARRAY
errors-next-token = FIELD_NAME
null

答案

测试前准备

# 更新配置文件
source /etc/profile# 启动 Neo4j
/opt/neo4j-community-3.5.35/bin/neo4j start# 注意
进入 Neo4j 界面,输入:':play movies',按 Enter 后。会出现一个向导界面,在第二个页面点击一个小播放键即可载入数据。

代码文件

package test_neo4j.neo4j.java.examples;import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;import org.neo4j.jdbc.Driver;//Connectpublic class JDBCNeo4j {public static void main(String[] args) throws SQLException, ClassNotFoundException {//**************Begin************************* // 使用 JDBC 连接 Neo4jConnection con = DriverManager.getConnection("jdbc:neo4j://localhost:7474/","neo4j","123456");// 创建连接Statement stmt = con.createStatement();// 查询数据ResultSet rs = stmt.executeQuery("MATCH (n:Person) RETURN n.born, n.name order by n.name limit 5");// 输出数据while(rs.next()) {System.out.println("出生年:" + rs.getString("n.born") + ",姓名:" + rs.getString("n.name"));}//**************End************************* }}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/236436.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【字符函数和字符串函数】

目录 字符分类函数字符转换函数strlen的使用和模拟实现strcpy的使用和模拟实现strcat的使用和模拟实现strcmp的使用和模拟实现strncpy的使用strncat的使用strncmp的使用strstr的使用和模拟实现strtok的使用strerror的使用字符串匹配优化-KMP算法 在编程的过程中,经常要处理字符…

什么是透明加密技术?透明加密有哪些优势?

透明加密技术是一种特殊的加密方法,它在用户毫不知情的情况下对数据进行加密和解密,保障了数据的安全性。用户在使用这种加密技术时,无需改变他们的日常操作习惯,加密和解密过程在后台自动进行,使得用户在享受数据安全…

基于springboot-“有光”摄影分享网站系统(2023年☆全网唯一)【附源码|数据库|表结构|万字文档(LW)|技术文档|说明文档】

主要功能 前台登录: 注册用户:用户账号、密码、姓名、手机号、身份证号、性别、邮箱 用户: ①首页、公告资讯展示、图片素材展示、活动展示、视频素材展示、查看更多 ②论坛、发布帖子、活动、活动标题、活动类型、公告资讯、公告标题、公告…

[原创][3]探究C#多线程开发细节-“用ConcurrentQueue<T>解决多线程的无顺序性的问题“

[简介] 常用网名: 猪头三 出生日期: 1981.XX.XXQQ: 643439947 个人网站: 80x86汇编小站 https://www.x86asm.org 编程生涯: 2001年~至今[共22年] 职业生涯: 20年 开发语言: C/C、80x86ASM、PHP、Perl、Objective-C、Object Pascal、C#、Python 开发工具: Visual Studio、Delphi…

金蝶Apusic应用服务器 任意文件上传漏洞复现

0x01 产品简介 金蝶Apusic应用服务器(Apusic Application Server,AAS)是一款标准、安全、高效、集成并具丰富功能的企业级应用服务器软件,全面支持JakartaEE8/9的技术规范,提供满足该规范的Web容器、EJB容器以及WebSer…

STM32F407-14.3.7-01PWM输入模式

PWM 输入模式 此模式是输入捕获模式的一个特例。其实现步骤与输入捕获模式基本相同,仅存在以下不同之处: 例如,可通过以下步骤对应用于 TI1① 的 PWM 的周期(位于 TIMx_CCR1⑨ 寄存器中)和占空 比(位于 …

rabbitmq消息队列实验

实验目的:实现异步通信 实验条件: 主机名 IP地址 组件 test1 20.0.0.10 rabbitmq服务 test2 20.0.0.20 rabbitmq服务 test3 20.0.0.30 rabbitmq服务 实验步骤: 1、安装rabbitmq服务 2、erlang进入命令行,查看版本 …

IDEA导入JavaWeb项目(非Maven)

IDEA导入JavaWeb(非Maven)项目教程 运行教程 亲爱的粉丝们,我深知你们对IDEA导入JAVAWeb工程的迫切需求。在这个充满竞争的时代,每一个项目都离不开高效的沟通。过程中需要对应的环境适配和软件…

提升Jmeter测试效率的9种参数化方法!

jmeter工具无论做接口测试还是性能测试,参数化都是一个必须掌握且非常有用的知识点。参数化的使用场景: 1)多个请求都是同一个ip地址,若服务器地址更换了,则脚本需要更改每个请求的ip 2)注册账号,不允许账…

计算机网络HTTP篇

目录 一、HTTP基本概念 二、GET 与 POST 2.1、GET 与 POST 有什么区别? 2.2、GET 和 POST 方法都是安全和幂等的吗? 三、HTTP 缓存 3.1、强制缓存: 3.2、协商缓存 四、HTTP 特性 4.1、HTTP/1.1 4.1.1、HTTP/1.1 的优点 4.1.2、HTT…

OSError: We couldnt connect to ‘https://huggingface.co‘

最近在做NerF类的数字人口型算法。需要加载一些huggingface上面的模型,但是无法连接上,如下图所示 于是先科学上网,打开https://huggingface.co/models 然后搜索提到的无法加载的模型,比如这里是cpierse/wav2vec2-large-xlsr-53-…

Unity DOTS《群体战斗弹幕游戏》核心技术分析之3D角色动画

最近DOTS发布了正式的版本, 我们来分享现在流行基于群体战斗的弹幕类游戏,实现的核心原理。今天给大家介绍大规模战斗群体3D角色的动画如何来实现。 DOTS 对角色动画支持的局限性 截止到Unity DOTS发布的版本1.0.16,目前还是无法很好的支持3D角色动画。在DOTS 的b…