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