摘要:簡介是基于語言實現(xiàn)的世界領先的圖形數(shù)據(jù)庫,是一個高性能的圖形存儲,具有成熟和強大的數(shù)據(jù)庫所需的所有功能,如友好的查詢語言和事務。對于許多應用程序,與關系數(shù)據(jù)庫相比,提供了數(shù)量級的性能優(yōu)勢。主要應用于圖檢索和關系計算。
Neo4j簡介
Neo4j是基于java語言實現(xiàn)的世界領先的圖形數(shù)據(jù)庫, 是一個高性能的圖形存儲,具有成熟和強大的數(shù)據(jù)庫所需的所有功能,如友好的查詢語言(Cypher)和ACID事務。對于許多應用程序,與關系數(shù)據(jù)庫相比,Neo4j提供了數(shù)量級的性能優(yōu)勢。主要應用于圖檢索和關系計算。其優(yōu)點在于:
節(jié)點沒上線(3.0以后去掉了限制)
擴展性很好,支持集群和企業(yè)版
數(shù)據(jù)ETL有豐富的工具支持,自帶GUI
良好的WebUI
更加詳細的介紹參考:https://neo4j.com/docs/gettin...
Neo4j安裝Neo4j在不同部署環(huán)境中的安裝,例如Linux,Mac OS,Windows,Debian,Docker或CAPI Flash,以下介紹在windows系統(tǒng)中的安裝方法:
1.下載最新安裝包
點擊以下地址:https://neo4j.com/download-ce...,選擇社區(qū)服務器下相應版本下載即可。
2.安裝Neo4j
解壓安裝包到相應目錄后在bin目錄下打開命令提示符或者任意地方打開命令提示符進入bin目錄下
如圖的四個命令:
(1)進入bin目錄下
(2)neo4j 查詢相應命令
(3)install-service 安裝Neo4j服務
(4)start 啟動服務
服務安裝成功之后瀏覽器輸入 http://localhost:7474/browser/ 即可訪問登錄頁面,其中用戶名密碼都為neo4j,登陸后可修改密碼,登錄頁面如下圖
其余環(huán)境的服務安裝方法可參考:https://neo4j.com/docs/operat...
大概了解了Neo4j和進行安裝之后,接下來就對Neo4j和springBoot進行一個簡單的整合,如圖實例我們依據(jù)圖中人物與電影的關系建立一個簡單的demo(圖片源自官方文檔)
建立一個springBoot項目
2.引入neo4j的pom
org.springframework.boot spring-boot-starter-data-neo4j
3.建立一個Person和Movie的實體類
@NodeEntity public class Person { @Id @GeneratedValue private Long id; private String name; private String born; public Person() {// 從 Neo4j API 2.0.5開始需要無參構造函數(shù) } public Person(String name, String born) { this.name = name; this.born = born; } //省略getter and setter
@NodeEntity public class Movie { @Id @GeneratedValue private Long id; private String title; private String released; public Movie() { } public Movie(String title, String released) { this.title = title; this.released = released; } //省略getter and setter
需要注意的是類上@NodeEntity,標識這是一個節(jié)點,實體類中還需要一個無參構造方法,從 Neo4j API 2.0.5開始需要的。
4.建立MovieRepository和PersonRepository
public interface MovieRepository extends CrudRepository{ Movie findByTitle(String title); }
public interface PersonRepository extends CrudRepository{ Person findByName(String name); }
其中繼承CrudRepository已經(jīng)可以實現(xiàn)簡單的CRUD了
5.在Person中建立movie與演員、導演的指向關系
@Relationship(type = "ACTED_IN", direction = Relationship.OUTGOING) public Setactors; public void addActor(Movie movie) { if (actors == null) { actors = new HashSet<>(); } actors.add(movie); } @Relationship(type = "DIRECTED", direction = Relationship.OUTGOING) public Set directors; public void addDirector(Movie movie) { if (directors == null) { directors = new HashSet<>(); } directors.add(movie); }
@Relationship這個注解表示關系,type是關系名稱,direction是方向,例子中的是person——>movie
6.application.properties配置文件中建立數(shù)據(jù)庫連接
#本地連接可以省略該行,非本地配置改對應ip #spring.data.neo4j.uri=bolt://localhost spring.data.neo4j.username=neo4j spring.data.neo4j.password=123456
7.單元測試
(1)創(chuàng)建movie
@Test public void testSaveMovie() { Movie m1 = new Movie("無問西東", "2018"); Movie m2 = new Movie("羅曼蒂克消亡史", "2016"); movieRepo.save(m1); movieRepo.save(m2); }
可以看到數(shù)據(jù)庫已經(jīng)建立兩部電影的相關節(jié)點
(2)創(chuàng)建person及其與movie的關系
@Test public void testSavePerson() { Person p1 = new Person("章子怡", "1979"); Person p2 = new Person("李芳芳", "1976"); Person p3 = new Person("程耳", "1970"); Movie m1 = movieRepo.findByTitle("羅曼蒂克消亡史"); Movie m2 = movieRepo.findByTitle("無問西東"); if (m1!=null) { p1.addActor(m1); p3.addDirector(m1); } if (m2!=null) { p1.addActor(m2); p2.addDirector(m2); } personRepo.save(p1); personRepo.save(p2); personRepo.save(p3); }
如圖,測試用例已經(jīng)建立起了電影與導演、演員之間的聯(lián)系
(3)findMovieByTitle
@Test public void testfindByTitle() { Movie movie = movieRepo.findByTitle("羅曼蒂克消亡史"); }
查詢出相應的結果符合預期
{ "id":26, "title":"羅曼蒂克消亡史", "released":"2016" }
(4)findPersonByName
@Test public void testfindByName() { Person person = personRepo.findByName("章子怡"); }
這里需注意的是,該演員對應了兩部電影,查詢個人信息的同時應該包含兩部電影
{ "id":27, "name":"章子怡", "born":"1979", "actors":[ { "id":25, "title":"無問西東", "released":"2018" }, { "id":26, "title":"羅曼蒂克消亡史", "released":"2016" } ] }
查詢結果也符合預期
還有很多findAll、delete就不在一一列舉了,至此springBoot與neo4j的簡單整合就完成了
demo源碼點擊下載
文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉載請注明本文地址:http://www.ezyhdfw.cn/yun/73036.html
摘要:和注解的方法返回值要一致刪除緩存在需要刪除緩存的方法上加注解,執(zhí)行完這個方法之后會將中對應的記錄刪除。代表返回值,意思是當返回碼不等于時不緩存,也就是等于時才緩存。返回值特定值如果被設置了如果沒有被設置例子自動將對應到并且返回原來對應的。 本文主要講 Redis 的使用,如何與 SpringBoot 項目整合,如何使用注解方式和 RedisTemplate 方式實現(xiàn)緩存。最后會給一個用...
摘要:自動配置會根據(jù)項目中的包依賴,自動做出配置,支持的自動配置如下非常多甚至包含了備注如果我們不需要自動配置,想關閉某一項的自動配置,該如何設置呢比如我們不想自動配置,想手動配置。 SpringBoot 入門 1、SpringBoot 入口類說明 1.1注解說明 showImg(https://segmentfault.com/img/bVbjvc9?w=707&h=232);@Sprin...
摘要:最近自己在網(wǎng)上搜索一些關于的教程,一直都沒有找到簡單明了的,所以就只能自己寫一篇初級入門的與當下最火的的整合。和需要自己進行填寫,否則就是默認的。進行測試就可以了,發(fā)現(xiàn)也是可以的,至此我們就完成了與的簡單集成。 最近自己在網(wǎng)上搜索一些關于mapper4的教程,一直都沒有找到簡單明了的,所以就只能自己寫一篇初級入門的mapper4與當下最火的springboot的整合。 1.首先我們需要...
閱讀 863·2021-09-06 15:02
閱讀 2490·2019-08-30 15:43
閱讀 2261·2019-08-30 11:26
閱讀 2427·2019-08-26 12:12
閱讀 3597·2019-08-23 18:24
閱讀 3336·2019-08-23 18:16
閱讀 749·2019-08-23 17:02
閱讀 2305·2019-08-23 15:34