最后
作为过来人,小编是整理了很多进阶架构视频资料、面试文档以及PDF的学习资料,针对上面一套系统大纲小编也有对应的相关进阶架构视频资料
《【云原生专题】基于Docker+Neo4j图数据库搭建企业级分布式应用拓扑图》,但是只介绍了使用Cypher语言在Neo4j的浏览器中执行增删查改的操作,现在我们想要基于SpringBoot来实现代码层面的增删查改。
一、环境搭建
最便捷的方式就是访问start.spring.io
,新建一个项目,选择的依赖有:
- spring-boot-starter-data-neo4j
- spring-boot-starter-web
- lombok
然后JDK需要选择11版本,因为我们当前使用的Neo4j版本是4.4.7,可以在Neo4j的浏览器中左下角“About Neo4j”中看到使用的版本号,其对应需要支持的JDK版本可以在官网中查到:
1. JDK 11
Neo4j 4.0 is the first major release that requires JDK 11. Custom extensions and procedures can be compiled now for JDK 11, for example, -target 11. It is generally recommended to use the latest available JDK 11 to access all available fixes and performance improvements.
如果本地Neo4j是通过Docker镜像安装的,我们可以进入镜像内部,使用命令查看Neo4j运行的Java版本信息:
# java -version
openjdk version "11.0.15" 2022-04-19
OpenJDK Runtime Environment 18.9 (build 11.0.15+10)
OpenJDK 64-Bit Server VM 18.9 (build 11.0.15+10, mixed mode, sharing)
如果不是通过Docker镜像安装的,那么本地就需要自行安装JDK11了,同样的,在运行如上我们下载的SpringBoot工程时,同样需要选择项目基于的JDK版本为11,然后才能正常运行。
二、Neo4jRepository介绍
Neo4jRepository是SpringData为我们提供的用来操作Neo4j数据库的接口,我们先来看看它的继承关系:
Neo4jRepository的继承关系
可以看到,通用的增删查改功能基本都有了,如果我们的数据库操作也是些简单的操作,那基本就不用再添加方法了,直接使用Neo4jRepository提供的方法即可。当然也支持我们自定义方法进行操作,这个下面再信息讲述。
三、代码演示
这里的代码示例,只是展示系统节点的增加、相互之间关系的创建,其它增删查改操作,可以自行摸索学习。
@Slf4j
@RestController
public class SystemController {
@Autowired
private SystemService systemService;
public static final String SUCCESS_RESULT = "success";
@GetMapping("/getAllSystemNode")
public List<SystemEntity> getAllSystemNode(){
return systemService.getAllSystemNode();
}
@GetMapping("/findSystemById/{id}")
public SystemEntity findSystemById(@PathVariable("id") Long id){
SystemEntity result = systemService.findSystemById(id);
log.info("{}", result);
return result;
}
@PostMapping("/addSystemNode")
public String addSystemNode(@RequestBody SystemEntity systemEntity){
systemService.addSystemNode(systemEntity);
return SUCCESS_RESULT;
}
@GetMapping("addInvokeRelation/{from}/{to}")
public String addInvokeRelation(@PathVariable("from") Long from, @PathVariable("to") Long to){
systemService.addInvokeRelation(from, to);
return SUCCESS_RESULT;
}
@GetMapping("addConsumeRelation/{from}/{to}")
public String addConsumeRelation(@PathVariable("from") Long from, @PathVariable("to") Long to){
systemService.addConsumeRelation(from, to);
return SUCCESS_RESULT;
}
@GetMapping("addProduceRelation/{from}/{to}")
public String addProduceRelation(@PathVariable("from") Long from, @PathVariable("to") Long to){
systemService.addProduceRelation(from, to);
return SUCCESS_RESULT;
}
}
@Slf4j
@Service
public class SystemService {
@Resource
private SystemRepository systemRepository;
public List<SystemEntity> getAllSystemNode(){
List<SystemEntity> systemEntityList = systemRepository.findAll();
log.info("查询所有的节点为:{}", systemEntityList);
return systemEntityList;
}
public void addSystemNode(SystemEntity systemEntity){
SystemEntity result = systemRepository.save(systemEntity);
log.info("添加节点后的返回结果为:{}", result);
}
public void addInvokeRelation(Long from, Long to){
systemRepository.addInvokeRelation(from, to);
}
public void addConsumeRelation(Long from, Long to){
systemRepository.addConsumeRelation(from, to);
}
**Java面试核心知识点笔记**
其中囊括了JVM、锁、并发、Java反射、Spring原理、微服务、Zookeeper、数据库、数据结构等大量知识点。
![蚂蚁金服(Java研发岗),26岁小伙斩获三面,收获Offer定级P6](https://img-blog.csdnimg.cn/img_convert/4224661364cd67cb052c57f282109525.webp?x-oss-process=image/format,png)
**Java中高级面试高频考点整理**
![蚂蚁金服(Java研发岗),26岁小伙斩获三面,收获Offer定级P6](https://img-blog.csdnimg.cn/img_convert/7ff48849d9abccdaec9daf870991c49c.webp?x-oss-process=image/format,png)
![蚂蚁金服(Java研发岗),26岁小伙斩获三面,收获Offer定级P6](https://img-blog.csdnimg.cn/img_convert/8009e21f3f597a64ea4586b6e2d84132.webp?x-oss-process=image/format,png)
**最后分享Java进阶学习及面试必备的视频教学**
![蚂蚁金服(Java研发岗),26岁小伙斩获三面,收获Offer定级P6](https://img-blog.csdnimg.cn/img_convert/face10142b09afa6b9eca0f40b48478a.webp?x-oss-process=image/format,png)
> **本文已被[CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】](https://bbs.csdn.net/forums/4f45ff00ff254613a03fab5e56a57acb)收录**
**[需要这份系统化的资料的朋友,可以点击这里获取](https://bbs.csdn.net/forums/4f45ff00ff254613a03fab5e56a57acb)**
频+实战项目源码】](https://bbs.csdn.net/forums/4f45ff00ff254613a03fab5e56a57acb)收录**
**[需要这份系统化的资料的朋友,可以点击这里获取](https://bbs.csdn.net/forums/4f45ff00ff254613a03fab5e56a57acb)**