使用 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.mzph.cn/news/187789.shtml

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

相关文章

万界星空科技MES生产管理系统的主要功能

万界星空科技MES/云MES生产管理系统主要包括以下功能模块: 生产计划管理:根据订单和生产计划,制定详细的调度表和车间生产经营计划,将生产计划和客户订单转化为具体的生产经营计划,消除有效的日常运营,大大…

知识图谱最简单的demo实现

一、简介 知识图谱整个建立过程可以分为以下几点: #mermaid-svg-zJuLB8k8EgBQF8M0 {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-zJuLB8k8EgBQF8M0 .error-icon{fill:#552222;}#mermaid-svg-zJuLB8k8E…

【C++干货铺】继承 | 多继承 | 虚继承

个人主页点击直达:小白不是程序媛 C系列专栏:C干货铺 代码仓库:Gitee 目录 继承的概念及定义 继承的概念 继承的定义 继承基类成员访问方式的变化 基类和派生类的赋值转化 继承中的作用域 派生类的默认成员函数 构造函数 拷贝构造…

基于Java SSM框架+Vue实现大学生兼职信息网站项目【项目源码+论文说明】计算机毕业设计

基于java的SSM框架Vue实现大学生兼职信息网站演示 摘要 21世纪的今天,随着社会的不断发展与进步,人们对于信息科学化的认识,已由低层次向高层次发展,由原来的感性认识向理性认识提高,管理工作的重要性已逐渐被人们所认…

nodejs的安装和验证

1.浏览器访问nodejs官网,根据操作系统选择对应版本的安装文件,如下图所示: 2.双击下载的安装文件,点击“Next”,如下图所示: 3.勾选“I accept the terms in the License Agreement”,然后点击“…

MIAOYUN荣获“2023中国赛宝信息技术应用创新优秀解决方案应用创新示范方向三等奖”

11月30日,2023(第四届)数字化转型推动高质量发展大会在中国海口成功召开,会上举办了2023中国赛宝信息技术应用创新优秀解决方案征集活动颁奖仪式。成都元来云志科技有限公司(简称“MIAOYUN”)联合国网浙江省…

应用于智慧工厂的AI边缘计算盒子+AI算法软硬一体化方案

智慧工厂解决方案,传统工厂/生产管理,普遍存在运营粗放、效率低、应变能力差、安全隐患突出、资源不平衡等“行业症状”; 以英码产品为核心的智能化场景解决方案,可以从本质上根治这些“症状”,如企业可利用智能预测系…

10.30 作业 C++

设计一个Per类&#xff0c;类中包含私有成员:姓名、年龄、指针成员身高、体重&#xff0c;再设计一个Stu类&#xff0c;类中包含私有成员:成绩、Per类对象p1&#xff0c;设计这两个类的构造函数、析构函数和拷贝构造函数。 #include <iostream>using namespace std;clas…

从零开始Inline Hook

中断表进入0环 通过中断门进入0环&#xff0c;首先了解一下中断门的构成 构造一个中断号 Base:函数地址 DPL:3 //因为三环使用调用门的条件就是CPL(即cs段选择子的RPL)<DPL P:1 //P为1时&#xff0c;中断表才有效 Segment Selector: 0x0008 //中断成功后切换自己的CPL 在…

拥抱复杂性:大模型的发展与挑战

原创 | 文 BFT机器人 大模型代表着机器学习和人工智能领域的前沿技术&#xff0c;它们的发展和应用对于推动科技进步和解决复杂问题具有重要意义。 01 什么是大模型&#xff1f; 大模型是指在计算机科学和人工智能领域中&#xff0c;具有庞大规模和复杂性的模型。这些模型通常…

STM32---时钟树

写在前面&#xff1a;一个 MCU 越复杂&#xff0c;时钟系统也会相应地变得复杂&#xff0c;如 STM32F1 的时钟系统比较复杂&#xff0c;不像简单的 51 单片机一个系统时钟就 可以解决一切。对于 STM32F1 系列的芯片&#xff0c;其有多个时钟源&#xff0c;构成了一个庞大的是时…

docker-compose部署zabbix+grafana

1.引言 1.1目的 zabbixgrafana实现图形化监控 2.部署环境 服务器ip服务版本192.168.5.137zabbix-server6.0.21192.168.5.137grafana10.2.2192.168.5.152zabbix-client6.0.21 3.部署zabbix-server 3.1 创建zabbix目录 mkdir zabbix3.2 编写docker-compose文件 cd zabbix…

【Linux】快速上手自动化构建工具make/makefile

&#x1f440;樊梓慕&#xff1a;个人主页 &#x1f3a5;个人专栏&#xff1a;《C语言》《数据结构》《蓝桥杯试题》《LeetCode刷题笔记》《实训项目》《C》《Linux》 &#x1f31d;每一个不曾起舞的日子&#xff0c;都是对生命的辜负 目录 前言 1.什么是make / makefile 2…

class-dump 混淆加固、保护与优化原理

​ 进行逆向时&#xff0c;经常需要dump可执行文件的头文件&#xff0c;用以确定类信息和方法信息&#xff0c;为hook相关方法提供更加详细的数据.class-dump的主要用于检查存储在Mach O文件的Objective-C中的运行时信息&#xff0c;为类&#xff0c;类别和协议生成声明信息&am…

leetcode-142-环形链表(C语言实现)

题目&#xff1a; 给定一个链表的头节点 head &#xff0c;返回链表开始入环的第一个节点。 如果链表无环&#xff0c;则返回 null。 如果链表中有某个节点&#xff0c;可以通过连续跟踪 next 指针再次到达&#xff0c;则链表中存在环。 为了表示给定链表中的环&#xff0c;评…

2023年中外Top10快公司研究报告

引言 在市场竞争激烈的环境中&#xff0c;每年都有企业实现显著的高速增长&#xff0c;其利润增长率和销售增长率等关键财务指标在短期内急剧上升。本研究报告精选了一批在2015年至2022年间&#xff0c;其营业收入或营业利润年增长率超过10,000%的企业进行深入分析。这一现象反…

使用SLS日志服务采集Kong网关的日志

一、阿里云SLS 官方的接入文档已比较丰富了&#xff0c;本文不意重复说明此事。 站在使用的角度&#xff0c;以采集Kong的日志为示例&#xff0c;说明我们应该如何治理日志。 说白了&#xff0c;本文是想给你怎么省钱作一个建议&#xff0c;希望不会让你公司也“降本增笑”。…

ios-class-guard - iOS代码混淆与加固实践

​ 目录 ios-class-guard - iOS代码混淆与加固实践 摘要 引言 一、class-dump 二、ios-class-guard 混淆原理 三、ios-class-guard 混淆结果 四、ios-class-guar 的使用 ios-class-guard 不支持 Swift ios-class-guard 不支持 iPhoneOS SDK ios-class-guard --sdk-ro…

模型层——单表操作

单表操作 一 ORM简介 查询数据层次图解&#xff1a;如果操作mysql&#xff0c;ORM是在pymysq之上又进行了一层封装 MVC或者MTV框架中包括一个重要的部分&#xff0c;就是ORM&#xff0c;它实现了数据模型与数据库的解耦&#xff0c;即数据模型的设计不需要依赖于特定的数据库…

Java网络通信

什么是网络编程 网络结构三要素 IP地址 端口号 通信协议 UDP TCP