乡下人产国偷v产偷v自拍,国产午夜片在线观看,婷婷成人亚洲综合国产麻豆,久久综合给合久久狠狠狠9

  • <output id="e9wm2"></output>
    <s id="e9wm2"><nobr id="e9wm2"><ins id="e9wm2"></ins></nobr></s>

    • 分享

      史上超全面的Neo4j使用指南

       江6ni1vqqy2e4f 2019-03-28
      • Create by yster@foxmail.com 2018-7-10

      • 我的博客:https://blog.csdn.net/yueshutong123

      • W3Cschool文檔:https://www./neo4j/neo4j_features_advantages.html

      • neo4j-examples:https://github.com/neo4j-examples/


      第一章:介紹

      Neo4j是什么

      Neo4j是一個(gè)高性能的,NOSQL圖形數(shù)據(jù)庫(kù),它將結(jié)構(gòu)化數(shù)據(jù)存儲(chǔ)在網(wǎng)絡(luò)上而不是表中。它是一個(gè)嵌入式的、基于磁盤的、具備完全的事務(wù)特性的Java持久化引擎,但是它將結(jié)構(gòu)化數(shù)據(jù)存儲(chǔ)在網(wǎng)絡(luò)(從數(shù)學(xué)角度叫做圖)上而不是表中。Neo4j也可以被看作是一個(gè)高性能的圖引擎,該引擎具有成熟數(shù)據(jù)庫(kù)的所有特性。程序員工作在一個(gè)面向?qū)ο蟮?、靈活的網(wǎng)絡(luò)結(jié)構(gòu)下而不是嚴(yán)格、靜態(tài)的表中——但是他們可以享受到具備完全的事務(wù)特性、企業(yè)級(jí)的數(shù)據(jù)庫(kù)的所有好處。

      Neo4j的特點(diǎn)

      • SQL就像簡(jiǎn)單的查詢語(yǔ)言Neo4j CQL

      • 它遵循屬性圖數(shù)據(jù)模型

      • 它通過(guò)使用Apache Lucence支持索引

      • 它支持UNIQUE約束

      • 它它包含一個(gè)用于執(zhí)行CQL命令的UI:Neo4j數(shù)據(jù)瀏覽器

      • 它支持完整的ACID(原子性,一致性,隔離性和持久性)規(guī)則

      • 它采用原生圖形庫(kù)與本地GPE(圖形處理引擎)

      • 它支持查詢的數(shù)據(jù)導(dǎo)出到JSON和XLS格式

      • 它提供了REST API,可以被任何編程語(yǔ)言(如Java,Spring,Scala等)訪問(wèn)

      • 它提供了可以通過(guò)任何UI MVC框架(如Node JS)訪問(wèn)的Java腳本

      • 它支持兩種Java API:Cypher API和Native Java API來(lái)開發(fā)Java應(yīng)用程序

      Neo4j的優(yōu)點(diǎn)

      • 它很容易表示連接的數(shù)據(jù)

      • 檢索/遍歷/導(dǎo)航更多的連接數(shù)據(jù)是非常容易和快速的

      • 它非常容易地表示半結(jié)構(gòu)化數(shù)據(jù)

      • Neo4j CQL查詢語(yǔ)言命令是人性化的可讀格式,非常容易學(xué)習(xí)

      • 它使用簡(jiǎn)單而強(qiáng)大的數(shù)據(jù)模型

      • 它不需要復(fù)雜的連接來(lái)檢索連接的/相關(guān)的數(shù)據(jù),因?yàn)樗苋菀讬z索它的相鄰節(jié)點(diǎn)或關(guān)系細(xì)節(jié)沒(méi)有連接或索引

      第二章:安裝

      1.環(huán)境

      Centos 7.4

      neo4j-community-3.4.1.tar.gz

      2.下載

      下載地址 https:///download/other-releases/

      下載

      wget https:///artifact.php?name=neo4j-community-3.4.1-unix.tar.gz

      解壓

      tar -zxvf neo4j-community-3.4.1.tar.gz

      3.開啟遠(yuǎn)程訪問(wèn)

      一、對(duì)于3.0以前的版本

      在安裝目錄的 $NEO4J_HOME/conf/neo4j.conf 文件內(nèi),找到下面一行,將注釋#號(hào)去掉就可以了 #dbms.connector.https.address=localhost:7473改為 dbms.connector.https.address=0.0.0.0:7473這樣,遠(yuǎn)程其他電腦可以用本機(jī)的IP或者域名后面跟上7474 端口就能打開web界面了 如: https://:7473

      當(dāng)然,你的操作系統(tǒng)的防火墻也要確保開放了7474端口才行,防火墻怎樣開放請(qǐng)自行針對(duì)自己的操作系統(tǒng)查找文檔

      二、對(duì)于3.1及以后的版本

      在安裝目錄的 $NEO4J_HOME/conf/neo4j.conf 文件內(nèi),找到下面一行,將注釋#號(hào)去掉就可以了 dbms.connectors.default_listen_address=0.0.0.0

      4.測(cè)試

      在bin目錄下,執(zhí)行命令:./neo4j start啟動(dòng),其他命令 { console | start | stop | restart | status } 

      訪問(wèn)http://IP地址:7474/, 出現(xiàn)下圖即代表安裝成功,頂部的$輸入框用來(lái)執(zhí)行下面的CQL語(yǔ)句。

      第三章:CQL

      1.CQL簡(jiǎn)介

      CQL代表Cypher查詢語(yǔ)言。 像Oracle數(shù)據(jù)庫(kù)具有查詢語(yǔ)言SQL,Neo4j具有CQL作為查詢語(yǔ)言。

      Neo4j CQL -

      • 它是Neo4j圖形數(shù)據(jù)庫(kù)的查詢語(yǔ)言。

      • 它是一種聲明性模式匹配語(yǔ)言

      • 它遵循SQL語(yǔ)法。

      • 它的語(yǔ)法是非常簡(jiǎn)單且人性化、可讀的格式。

      如Oracle SQL -

      • Neo4j CQL 已命令來(lái)執(zhí)行數(shù)據(jù)庫(kù)操作。

      • Neo4j CQL 支持多個(gè)子句像在哪里,順序等,以非常簡(jiǎn)單的方式編寫非常復(fù)雜的查詢。

      • NNeo4j CQL 支持一些功能,如字符串,Aggregation.In 加入他們,它還支持一些關(guān)系功能。

      2.Neo4j CQL命令/條款

      常用的Neo4j CQL命令/條款如下:

      S.No.

      CQL命令/條

      用法

      1。

      CREATE 創(chuàng)建

      創(chuàng)建節(jié)點(diǎn),關(guān)系和屬性

      2。

      MATCH 匹配

      檢索有關(guān)節(jié)點(diǎn),關(guān)系和屬性數(shù)據(jù)

      3。

      RETURN 返回

      返回查詢結(jié)果

      4。

      WHERE 哪里

      提供條件過(guò)濾檢索數(shù)據(jù)

      5。

      DELETE 刪除

      刪除節(jié)點(diǎn)和關(guān)系

      6。

      REMOVE 移除

      刪除節(jié)點(diǎn)和關(guān)系的屬性

      7。

      ORDER BY以…排序

      排序檢索數(shù)據(jù)

      8。

      SET 組

      添加或更新標(biāo)簽

      3.Neo4j CQL 函數(shù)

      以下是常用的Neo4j CQL函數(shù):

      S.No.

      定制列表功能

      用法

      1。

      String 字符串

      它們用于使用String字面量。

      2。

      Aggregation 聚合

      它們用于對(duì)CQL查詢結(jié)果執(zhí)行一些聚合操作。

      3。

      Relationship 關(guān)系

      他們用于獲取關(guān)系的細(xì)節(jié),如startnode,endnode等。

      我們將在后面的章節(jié)中詳細(xì)討論所有Neo4j CQL命令,子句和函數(shù)語(yǔ)法,用法和示例。

      4.Neo4j CQL數(shù)據(jù)類型

      這些數(shù)據(jù)類型與Java語(yǔ)言類似。 它們用于定義節(jié)點(diǎn)或關(guān)系的屬性

      Neo4j CQL支持以下數(shù)據(jù)類型:

      S.No.

      CQL數(shù)據(jù)類型

      用法

      1.

      boolean

      用于表示布爾文字:true,false。

      2.

      byte

      用于表示8位整數(shù)。

      3.

      short

      用于表示16位整數(shù)。

      4.

      int

      用于表示32位整數(shù)。

      5.

      long

      用于表示64位整數(shù)。

      6.

      float

      I用于表示32位浮點(diǎn)數(shù)。

      7.

      double

      用于表示64位浮點(diǎn)數(shù)。

      8.

      char

      用于表示16位字符。

      9.

      String

      用于表示字符串。

      第四章:命令

      1.CREATE創(chuàng)建

      Neo4j CQL創(chuàng)建一個(gè)沒(méi)有屬性的節(jié)點(diǎn)

      CREATE (<node-name>:<label-name>)

      語(yǔ)法說(shuō)明

      規(guī)范說(shuō)法是節(jié)點(diǎn)標(biāo)簽名稱,其實(shí)相當(dāng)于Mysql數(shù)據(jù)庫(kù)中的表名,而是節(jié)點(diǎn)名稱,其實(shí)代指創(chuàng)建的此行數(shù)據(jù)。

      示例

      CREATE (emp:Employee)

      或者

      CREATE (:Employee)

      Neo4j CQL創(chuàng)建具有屬性的節(jié)點(diǎn)

      Neo4j CQL“CREATE”命令用于創(chuàng)建帶有屬性的節(jié)點(diǎn)。 它創(chuàng)建一個(gè)具有一些屬性(鍵值對(duì))的節(jié)點(diǎn)來(lái)存儲(chǔ)數(shù)據(jù)。

      CREATE (   <node-name>:<label-name>   {          <key>:<Value>      ........      <n-key>:<n-Value>   })

      示例

      CREATE (dept:Dept { deptno:10,dname:'Accounting',location:'Hyderabad' })

      創(chuàng)建多個(gè)標(biāo)簽到節(jié)點(diǎn)

      語(yǔ)法:

      CREATE (<node-name>:<label-name1>:<label-name2>.....:<label-namen>)

      示例

      CREATE (m:Movie:Cinema:Film:Picture)

      2.MATCH查詢

      Neo4j CQL MATCH命令用于

      • 從數(shù)據(jù)庫(kù)獲取有關(guān)節(jié)點(diǎn)和屬性的數(shù)據(jù)

      • 從數(shù)據(jù)庫(kù)獲取有關(guān)節(jié)點(diǎn),關(guān)系和屬性的數(shù)據(jù)

      MATCH命令語(yǔ)法:

      MATCH (   <node-name>:<label-name>)

      示例

      MATCH (dept:Dept)

      但是執(zhí)行后會(huì)報(bào)錯(cuò):

      Neo.ClientError.Statement.SyntaxError: Query cannot conclude with MATCH (must be RETURN or an update clause) (line 1, column 1 (offset: 0))

      如果你觀察到錯(cuò)誤消息,它告訴我們,我們可以使用MATCH命令與RETURN子句或UPDATA子句。

      3.RETURN返回

      Neo4j CQL RETURN子句用于 -

      • 檢索節(jié)點(diǎn)的某些屬性

      • 檢索節(jié)點(diǎn)的所有屬性

      • 檢索節(jié)點(diǎn)和關(guān)聯(lián)關(guān)系的某些屬性

      • 檢索節(jié)點(diǎn)和關(guān)聯(lián)關(guān)系的所有屬性

      RETURN命令語(yǔ)法:

      RETURN <node-name>.<property1-name>, ........ <node-name>.<propertyn-name>

      示例

      MATCH (e:Employee) RETURN e

      MATCH (dept: Dept)RETURN dept.deptno,dept.dname,dept.location

      4.關(guān)系基礎(chǔ)

      Neo4j圖數(shù)據(jù)庫(kù)遵循屬性圖模型來(lái)存儲(chǔ)和管理其數(shù)據(jù)。

      根據(jù)屬性圖模型,關(guān)系應(yīng)該是定向的。 否則,Neo4j將拋出一個(gè)錯(cuò)誤消息。

      基于方向性,Neo4j關(guān)系被分為兩種主要類型。

      • 單向關(guān)系

      • 雙向關(guān)系

      使用新節(jié)點(diǎn)創(chuàng)建關(guān)系

      示例

      CREATE (e:Employee)-[r:DemoRelation]->(c:Employee)

      這句會(huì)創(chuàng)建節(jié)點(diǎn)e,節(jié)點(diǎn)c,以及e -> c的關(guān)系r,這里需要注意方向,比如雙向是

      CREATE (e:Employee)<-[r:DemoRelation]->(c:Employee)

      使用已知節(jié)點(diǎn)創(chuàng)建帶屬性的關(guān)系:

      MATCH (<node1-label-name>:<node1-name>),(<node2-label-name>:<node2-name>)CREATE      (<node1-label-name>)-[<relationship-label-name>:<relationship-name>    {<define-properties-list>}]->(<node2-label-name>)RETURN <relationship-label-name>

      還是一系列鍵值對(duì)

      示例

      MATCH (cust:Customer),(cc:CreditCard) CREATE (cust)-[r:DO_SHOPPING_WITH{shopdate:'12/12/2014',price:55000}]->(cc) RETURN r

      檢索關(guān)系節(jié)點(diǎn)的詳細(xì)信息:

      MATCH (<node1-label-name>)-[<relationship-label-name>:<relationship-name>]->(<node2-label-name>)RETURN <relationship-label-name>

      示例

      MATCH (cust)-[r:DO_SHOPPING_WITH]->(cc) RETURN cust,cc

      5.WHERE子句

      像SQL一樣,Neo4j CQL在CQL MATCH命令中提供了WHERE子句來(lái)過(guò)濾MATCH查詢的結(jié)果。

      簡(jiǎn)單WHERE子句語(yǔ)法

      WHERE <property-name> <comparison-operator> <value>

      語(yǔ)法說(shuō)明:

      S.No.

      語(yǔ)法元素

      描述

      1

      WHERE

      它是一個(gè)Neo4j CQL關(guān)鍵字。

      2

      <屬性名稱>

      它是節(jié)點(diǎn)或關(guān)系的屬性名稱。

      3

      <比較運(yùn)算符>

      它是Neo4j CQL比較運(yùn)算符之一。

      4

      <值>

      它是一個(gè)字面值,如數(shù)字文字,字符串文字等。

      Neo4j CQL中的比較運(yùn)算符

      Neo4j 支持以下的比較運(yùn)算符,在 Neo4j CQL WHERE 子句中使用來(lái)支持條件

      S.No.

      布爾運(yùn)算符

      描述

      1.

      =

      它是Neo4j CQL“等于”運(yùn)算符。

      2.

      <>

      它是一個(gè)Neo4j CQL“不等于”運(yùn)算符。

      3.

      <

      它是一個(gè)Neo4j CQL“小于”運(yùn)算符。

      4.

      >

      它是一個(gè)Neo4j CQL“大于”運(yùn)算符。

      5.

      <=

      它是一個(gè)Neo4j CQL“小于或等于”運(yùn)算符。

      6.

      =

      它是一個(gè)Neo4j CQL“大于或等于”運(yùn)算符。

      我們可以使用布爾運(yùn)算符在同一命令上放置多個(gè)條件。

      Neo4j CQL中的布爾運(yùn)算符

      Neo4j支持以下布爾運(yùn)算符在Neo4j CQL WHERE子句中使用以支持多個(gè)條件。

      S.No.

      布爾運(yùn)算符

      描述

      1

      AND

      它是一個(gè)支持AND操作的Neo4j CQL關(guān)鍵字。

      2

      OR

      它是一個(gè)Neo4j CQL關(guān)鍵字來(lái)支持OR操作。

      3

      NOT

      它是一個(gè)Neo4j CQL關(guān)鍵字支持NOT操作。

      4

      XOR

      它是一個(gè)支持XOR操作的Neo4j CQL關(guān)鍵字。

      示例

      MATCH (emp:Employee) WHERE emp.name = 'Abc' OR emp.name = 'Xyz'RETURN emp

      利用WHERE創(chuàng)建指定關(guān)系節(jié)點(diǎn):

      MATCH (cust:Customer),(cc:CreditCard) WHERE cust.id = '1001' AND cc.id= '5001' CREATE (cust)-[r:DO_SHOPPING_WITH{shopdate:'12/12/2014',price:55000}]->(cc) RETURN r

      有必要補(bǔ)充一下,可以不使用WHERE達(dá)到WHERE的一些效果,比如

      MATCH p=(m:Bot{id:123})<-[:BotRelation]->(:Bot) RETURN p

      6.DELETE刪除

      Neo4j使用CQL DELETE子句

      • 刪除節(jié)點(diǎn)。

      • 刪除節(jié)點(diǎn)及相關(guān)節(jié)點(diǎn)和關(guān)系。

      DELETE節(jié)點(diǎn)子句語(yǔ)法

      DELETE <node-name-list>

      示例

      MATCH (e: Employee) DELETE e

      DELETE節(jié)點(diǎn)和關(guān)系子句語(yǔ)法

      DELETE <node1-name>,<node2-name>,<relationship-name>

      示例

      MATCH (cc: CreditCard)-[rel]-(c:Customer) DELETE cc,c,rel

      7.REMOVE刪除

      有時(shí)基于我們的客戶端要求,我們需要向現(xiàn)有節(jié)點(diǎn)或關(guān)系添加或刪除屬性。

      我們使用Neo4j CQL SET子句向現(xiàn)有節(jié)點(diǎn)或關(guān)系添加新屬性。

      我們使用Neo4j CQL REMOVE子句來(lái)刪除節(jié)點(diǎn)或關(guān)系的現(xiàn)有屬性。

      Neo4j CQL REMOVE命令用于

      • 刪除節(jié)點(diǎn)或關(guān)系的標(biāo)簽

      • 刪除節(jié)點(diǎn)或關(guān)系的屬性

      Neo4j CQL DELETE和REMOVE命令之間的主要區(qū)別 -

      • DELETE操作用于刪除節(jié)點(diǎn)和關(guān)聯(lián)關(guān)系。

      • REMOVE操作用于刪除標(biāo)簽和屬性。

      Neo4j CQL DELETE和REMOVE命令之間的相似性 -

      • 這兩個(gè)命令不應(yīng)單獨(dú)使用。

      • 兩個(gè)命令都應(yīng)該與MATCH命令一起使用。

      1.REMOVE屬性子句語(yǔ)法

      REMOVE <node-name>.<property1-name>,<node-name>.<property2-name>

      語(yǔ)法說(shuō)明:

      S.No.

      語(yǔ)法元素

      描述

      1。

      它是節(jié)點(diǎn)的名稱。

      2。

      它是節(jié)點(diǎn)的屬性名稱。

      示例

      這里我們可以觀察到DebitCard節(jié)點(diǎn)包含6個(gè)屬性。

      在數(shù)據(jù)瀏覽器上鍵入以下命令刪除cvv屬性

      MATCH (dc:DebitCard) REMOVE dc.cvvRETURN dc

      2.REMOVE一個(gè)Label子句語(yǔ)法:

      REMOVE <label-name-list>

      S.No.

      語(yǔ)法元素

      描述

      1.

      REMOVE

      它是一個(gè)Neo4j CQL關(guān)鍵字。

      2.

      它是一個(gè)標(biāo)簽列表,用于永久性地從節(jié)點(diǎn)或關(guān)系中刪除它。

      語(yǔ)法

      <node-name>:<label2-name>, .... <node-name>:<labeln-name>

      示例

      1.我們創(chuàng)建一個(gè)含有兩個(gè)標(biāo)簽的節(jié)點(diǎn):

      CREATE (m:Movie:Pic)

      2.查詢?cè)摴?jié)點(diǎn)

      MATCH (n:Movie) RETURN n

      3.刪除標(biāo)簽

      MATCH (m:Movie) REMOVE m:Pic

      4.再次查詢

      8.SET子句

      有時(shí),根據(jù)我們的客戶端要求,我們需要向現(xiàn)有節(jié)點(diǎn)或關(guān)系添加新屬性。

      要做到這一點(diǎn),Neo4j CQL提供了一個(gè)SET子句。

      Neo4j CQL已提供SET子句來(lái)執(zhí)行以下操作。

      • 向現(xiàn)有節(jié)點(diǎn)或關(guān)系添加新屬性

      • 添加或更新屬性值

      SET子句語(yǔ)法

      SET <node-label-name>.<property1-name>,...<node-laben-name>.<propertyn-name>

      語(yǔ)法說(shuō)明:

      S.No.

      語(yǔ)法元素

      描述

      1

      <節(jié)點(diǎn)標(biāo)簽名稱>

      這是一個(gè)節(jié)點(diǎn)的標(biāo)簽名稱。

      2

      <屬性名稱>

      它是一個(gè)節(jié)點(diǎn)的屬性名。

      示例

      MATCH (dc:DebitCard)SET dc.atm_pin = 3456RETURN dc

      9.ORDER BY排序

      Neo4j CQL ORDER BY子句

      Neo4j CQL在MATCH命令中提供了“ORDER BY”子句,對(duì)MATCH查詢返回的結(jié)果進(jìn)行排序。

      我們可以按升序或降序?qū)π羞M(jìn)行排序。

      默認(rèn)情況下,它按升序?qū)π羞M(jìn)行排序。 如果我們要按降序?qū)λ鼈冞M(jìn)行排序,我們需要使用DESC子句。

      ORDER BY子句語(yǔ)法

      ORDER BY <property-name-list> [DESC]

      語(yǔ)法:

      <node-label-name>.<property1-name>,<node-label-name>.<property2-name>, .... <node-label-name>.<propertyn-name>

      S.No.

      語(yǔ)法元素

      描述

      1。

      它是節(jié)點(diǎn)的標(biāo)簽名稱。

      2。

      它是節(jié)點(diǎn)的屬性名稱。

      示例

      MATCH (emp:Employee)RETURN emp.empid,emp.name,emp.salary,emp.deptnoORDER BY emp.name

      10.UNION子句

      與SQL一樣,Neo4j CQL有兩個(gè)子句,將兩個(gè)不同的結(jié)果合并成一組結(jié)果

      • UNION

      • UNION ALL

      UNION子句

      它將兩組結(jié)果中的公共行組合并返回到一組結(jié)果中。 它不從兩個(gè)節(jié)點(diǎn)返回重復(fù)的行。

      限制:

      結(jié)果列類型和來(lái)自兩組結(jié)果的名稱必須匹配,這意味著列名稱應(yīng)該相同,列的數(shù)據(jù)類型應(yīng)該相同。

      UNION子句語(yǔ)法

      <MATCH Command1>   UNION<MATCH Command2>

      S.No.

      語(yǔ)法元素

      描述

      1。

      它是CQL MATCH命令,由UNION子句使用。

      2。

      它是CQL MATCH命令兩個(gè)由UNION子句使用。

      3。

      UNION

      它是UNION子句的Neo4j CQL關(guān)鍵字。

      注意 -

      如果這兩個(gè)查詢不返回相同的列名和數(shù)據(jù)類型,那么它拋出一個(gè)錯(cuò)誤。

      示例

      MATCH (cc:CreditCard) RETURN cc.id,cc.numberUNIONMATCH (dc:DebitCard) RETURN dc.id,dc.number

      UNION ALL子句

      它結(jié)合并返回兩個(gè)結(jié)果集的所有行成一個(gè)單一的結(jié)果集。它還返回由兩個(gè)節(jié)點(diǎn)重復(fù)行。

      限制

      結(jié)果列類型,并從兩個(gè)結(jié)果集的名字必須匹配,這意味著列名稱應(yīng)該是相同的,列的數(shù)據(jù)類型應(yīng)該是相同的。

      UNION ALL子句語(yǔ)法

      <MATCH Command1>UNION ALL<MATCH Command2>

      示例

      MATCH (cc:CreditCard) RETURN cc.id,cc.numberUNION ALLMATCH (dc:DebitCard) RETURN dc.id,dc.number

      11.LIMIT和SKIP子句

      Neo4j CQL已提供LIMIT子句和SKIP來(lái)過(guò)濾或限制查詢返回的行數(shù)。

      簡(jiǎn)單來(lái)說(shuō):LIMIT返回前幾行,SKIP返回后幾行。

      LIMIT示例

      MATCH (emp:Employee) RETURN empLIMIT 2

      它只返回Top的兩個(gè)結(jié)果,因?yàn)槲覀兌x了limit = 2。這意味著前兩行。

      SKIP示例

      MATCH (emp:Employee) RETURN empSKIP 2

      它只返回來(lái)自Bottom的兩個(gè)結(jié)果,因?yàn)槲覀兌x了skip = 2。這意味著最后兩行。

      12.MERGE命令

      Neo4j使用CQL MERGE命令 -

      • 創(chuàng)建節(jié)點(diǎn),關(guān)系和屬性

      • 為從數(shù)據(jù)庫(kù)檢索數(shù)據(jù)

      MERGE命令是CREATE命令和MATCH命令的組合。

      MERGE = CREATE + MATCH

      Neo4j CQL MERGE命令在圖中搜索給定模式,如果存在,則返回結(jié)果

      如果它不存在于圖中,則它創(chuàng)建新的節(jié)點(diǎn)/關(guān)系并返回結(jié)果。

      Neo4j CQL MERGE語(yǔ)法

      MERGE (<node-name>:<label-name>{ <key>:<1-Value> ..... <n-key>:<n-Value>})

      注意 -

      Neo4j CQL MERGE命令語(yǔ)法與CQL CREATE命令類似。

      我們將使用這兩個(gè)命令執(zhí)行以下操作 -

      • 創(chuàng)建具有一個(gè)屬性的配置文件節(jié)點(diǎn):Id,名稱

      • 創(chuàng)建具有相同屬性的同一個(gè)Profile節(jié)點(diǎn):Id,Name

      • 檢索所有Profile節(jié)點(diǎn)詳細(xì)信息并觀察結(jié)果

      我們將使用CREATE命令執(zhí)行這些操作:

      MERGE (gp2:GoogleProfile2{ Id: 201402,Name:'Nokia'})
      MERGE (gp2:GoogleProfile2{ Id: 201402,Name:'Nokia'})
      MATCH  (gp1:GoogleProfile1) RETURN gp1.Id,gp1.Name

      如果我們觀察上面的查詢結(jié)果,它只顯示一行,因?yàn)镃QL MERGE命令檢查該節(jié)點(diǎn)在數(shù)據(jù)庫(kù)中是否可用。 如果它不存在,它創(chuàng)建新節(jié)點(diǎn)。 否則,它不創(chuàng)建新的。

      通過(guò)觀察這些結(jié)果,我們可以說(shuō),CQL MERGE命令將新的節(jié)點(diǎn)添加到數(shù)據(jù)庫(kù),只有當(dāng)它不存在。

      13.NULL值

      Neo4j CQL將空值視為對(duì)節(jié)點(diǎn)或關(guān)系的屬性的缺失值或未定義值。

      當(dāng)我們創(chuàng)建一個(gè)具有現(xiàn)有節(jié)點(diǎn)標(biāo)簽名稱但未指定其屬性值的節(jié)點(diǎn)時(shí),它將創(chuàng)建一個(gè)具有NULL屬性值的新節(jié)點(diǎn)。

      讓我們用一個(gè)例子來(lái)看這個(gè)。

      MATCH (e:Employee) WHERE e.id IS NOT NULLRETURN e.id,e.name,e.sal,e.deptno

      提供了一個(gè)WHERE子句來(lái)過(guò)濾該行,即Id屬性不應(yīng)該包含NULL值。

      MATCH (e:Employee) WHERE e.id IS NULLRETURN e.id,e.name,e.sal,e.deptno

      這里我們使用IS操作符來(lái)僅返回NULL行。

      14.IN操作符

      與SQL一樣,Neo4j CQL提供了一個(gè)IN運(yùn)算符,以便為CQL命令提供值的集合。

      IN操作符語(yǔ)法

      IN[<Collection-of-values>]

      它是由逗號(hào)運(yùn)算符分隔的值的集合。

      示例

      MATCH (e:Employee) WHERE e.id IN [123,124]RETURN e.id,e.name,e.sal,e.deptno

      15.INDEX索引

      Neo4j SQL支持節(jié)點(diǎn)或關(guān)系屬性上的索引,以提高應(yīng)用程序的性能。

      我們可以為具有相同標(biāo)簽名稱的所有節(jié)點(diǎn)的屬性創(chuàng)建索引。

      我們可以在MATCH或WHERE或IN運(yùn)算符上使用這些索引列來(lái)改進(jìn)CQL Command的執(zhí)行。

      Neo4J索引操作

      • Create Index 創(chuàng)建索引

      • Drop Index 丟棄索引

      我們將在本章中用示例來(lái)討論這些操作。

      創(chuàng)建索引的語(yǔ)法:

      CREATE INDEX ON :<label_name> (<property_name>)

      注意:-

      冒號(hào)(:)運(yùn)算符用于引用節(jié)點(diǎn)或關(guān)系標(biāo)簽名稱。

      上述語(yǔ)法描述它在節(jié)點(diǎn)或關(guān)系的的上創(chuàng)建一個(gè)新索引。

      示例

      CREATE INDEX ON :Customer (name)

      刪除索引的語(yǔ)法:

      DROP INDEX ON :<label_name> (<property_name>)

      示例

      DROP INDEX ON :Customer (name)

      16.UNIQUE約束

      在Neo4j數(shù)據(jù)庫(kù)中,CQL CREATE命令始終創(chuàng)建新的節(jié)點(diǎn)或關(guān)系,這意味著即使您使用相同的值,它也會(huì)插入一個(gè)新行。 根據(jù)我們對(duì)某些節(jié)點(diǎn)或關(guān)系的應(yīng)用需求,我們必須避免這種重復(fù)。 然后我們不能直接得到這個(gè)。 我們應(yīng)該使用一些數(shù)據(jù)庫(kù)約束來(lái)創(chuàng)建節(jié)點(diǎn)或關(guān)系的一個(gè)或多個(gè)屬性的規(guī)則。

      像SQL一樣,Neo4j數(shù)據(jù)庫(kù)也支持對(duì)NODE或Relationship的屬性的UNIQUE約束

      UNIQUE約束的優(yōu)點(diǎn)

      • 避免重復(fù)記錄。

      • 強(qiáng)制執(zhí)行數(shù)據(jù)完整性規(guī)則

      創(chuàng)建唯一約束語(yǔ)法

      CREATE CONSTRAINT ON (<label_name>)ASSERT <property_name> IS UNIQUE

      語(yǔ)法說(shuō)明:

      S.No.

      語(yǔ)法元素

      描述

      1。

      CREATE CONSTRAINT ON

      它是一個(gè)Neo4j CQL關(guān)鍵字。

      2。

      它是節(jié)點(diǎn)或關(guān)系的標(biāo)簽名稱。

      3。

      ASSERT

      它是一個(gè)Neo4j CQL關(guān)鍵字。

      4。

      它是節(jié)點(diǎn)或關(guān)系的屬性名稱。

      5。

      IS UNIQUE

      它是一個(gè)Neo4j CQL關(guān)鍵字,通知Neo4j數(shù)據(jù)庫(kù)服務(wù)器創(chuàng)建一個(gè)唯一約束。

      注意:-

      上述語(yǔ)法描述了只需要 節(jié)點(diǎn)或關(guān)系就可以創(chuàng)造一個(gè)獨(dú)特的約束。

      示例

      CREATE CONSTRAINT ON (cc:CreditCard)ASSERT cc.number IS UNIQUE

      注意

      如果創(chuàng)建約束時(shí)節(jié)點(diǎn)屬性有重復(fù)值,Neo4j DB服務(wù)器將會(huì)拋出一個(gè)錯(cuò)誤,表示無(wú)法創(chuàng)建。

      刪除UNIQUE約束語(yǔ)法:

      DROP CONSTRAINT ON (<label_name>)ASSERT <property_name> IS UNIQUE

      示例

      DROP CONSTRAINT ON (cc:CreditCard)ASSERT cc.number IS UNIQUE

      17.DISTINCT獨(dú)特

      這個(gè)函數(shù)的用法就像SQL中的distinct關(guān)鍵字,返回的是所有不同值。

      示例

      MATCH (n:Movie) RETURN Distinct(n.name)

      返回的是

      第五章:解釋

      1.圖形字體

      關(guān)于Neo4j提供的圖形瀏覽器,我們可以從其中查看節(jié)點(diǎn)的屬性,或者改變其中的節(jié)點(diǎn)的大小顏色。

      2.ID屬性

      在Neo4j中,“Id”是節(jié)點(diǎn)和關(guān)系的默認(rèn)內(nèi)部屬性。 這意味著,當(dāng)我們創(chuàng)建一個(gè)新的節(jié)點(diǎn)或關(guān)系時(shí),Neo4j數(shù)據(jù)庫(kù)服務(wù)器將為內(nèi)部使用分配一個(gè)數(shù)字。 它會(huì)自動(dòng)遞增。

      我們從一個(gè)例子去看:

      新增一個(gè)節(jié)點(diǎn)

      CREATE (tweet:Tweet{message:'Hello'})

      查看該節(jié)點(diǎn)

      MATCH (n:Tweet) RETURN n

      3.Caption標(biāo)題

      所謂的Caption標(biāo)題,就是更改Neo4j瀏覽器的節(jié)點(diǎn)顯示的文字(圓圈內(nèi)部)。比如

      我們點(diǎn)擊下圖所示:

      圓圈內(nèi)部變?yōu)榱薸d值。

      第六章:函數(shù)

      1.字符串函數(shù)

      與SQL一樣,Neo4J CQL提供了一組String函數(shù),用于在CQL查詢中獲取所需的結(jié)果。

      這里我們將討論一些重要的和經(jīng)常使用的功能。

      字符串函數(shù)列表

      S.No.

      功能

      描述

      1。

      UPPER

      它用于將所有字母更改為大寫字母。

      2。

      LOWER

      它用于將所有字母改為小寫字母。

      3。

      SUBSTRING

      它用于獲取給定String的子字符串。

      4。

      REPLACE

      它用于替換一個(gè)字符串的子字符串。

      注意:所有CQL函數(shù)應(yīng)使用“()”括號(hào)。

      現(xiàn)在我們將通過(guò)示例詳細(xì)討論每個(gè)Neo4J CQL字符串函數(shù)

      1.UPPER

      它需要一個(gè)字符串作為輸入并轉(zhuǎn)換為大寫字母。 所有CQL函數(shù)應(yīng)使用“()”括號(hào)。

      函數(shù)語(yǔ)法

      UPPER (<input-string>)

      注意:-

      可以是來(lái)自Neo4J數(shù)據(jù)庫(kù)的節(jié)點(diǎn)或關(guān)系的屬性名稱。

      示例

      MATCH (e:Employee) RETURN e.id,UPPER(e.name),e.sal,e.deptno

      2.LOWER

      它需要一個(gè)字符串作為輸入并轉(zhuǎn)換為小寫字母。 所有CQL函數(shù)應(yīng)使用“()”括號(hào)。

      函數(shù)語(yǔ)法

      LOWER (<input-string>)

      注意:-

      可以是來(lái)自Neo4J數(shù)據(jù)庫(kù)的節(jié)點(diǎn)或關(guān)系的屬性名稱

      MATCH (e:Employee) RETURN e.id,LOWER(e.name),e.sal,e.deptno

      3.SUBSTRING

      它接受一個(gè)字符串作為輸入和兩個(gè)索引:一個(gè)是索引的開始,另一個(gè)是索引的結(jié)束,并返回從StartInded到EndIndex-1的子字符串。 所有CQL函數(shù)應(yīng)使用“()”括號(hào)。

      函數(shù)的語(yǔ)法

      SUBSTRING(<input-string>,<startIndex> ,<endIndex>)

      注意:-

      在Neo4J CQL中,如果一個(gè)字符串包含n個(gè)字母,則它的長(zhǎng)度為n,索引從0開始,到n-1結(jié)束。

      是SUBSTRING函數(shù)的索引值。

      是可選的。 如果我們省略它,那么它返回給定字符串的子串從startIndex到字符串的結(jié)尾。

      示例

      MATCH (e:Employee) RETURN e.id,SUBSTRING(e.name,0,2),e.sal,e.deptno

      2.AGGREGATION聚合

      和SQL一樣,Neo4j CQL提供了一些在RETURN子句中使用的聚合函數(shù)。 它類似于SQL中的GROUP BY子句。

      我們可以使用MATCH命令中的RETURN +聚合函數(shù)來(lái)處理一組節(jié)點(diǎn)并返回一些聚合值。

      聚合函數(shù)列表

      S.No.

      聚集功能

      描述

      1。

      COUNT

      它返回由MATCH命令返回的行數(shù)。

      2。

      MAX

      它從MATCH命令返回的一組行返回最大值。

      3。

      MIN

      它返回由MATCH命令返回的一組行的最小值。

      4。

      SUM

      它返回由MATCH命令返回的所有行的求和值。

      5。

      AVG

      它返回由MATCH命令返回的所有行的平均值。

      現(xiàn)在我們將通過(guò)示例詳細(xì)討論每個(gè)Neo4j CQL AGGREGATION函數(shù)

      計(jì)數(shù)

      它從MATCH子句獲取結(jié)果,并計(jì)算結(jié)果中出現(xiàn)的行數(shù),并返回該計(jì)數(shù)值。 所有CQL函數(shù)應(yīng)使用“()”括號(hào)。

      函數(shù)語(yǔ)法

      COUNT(<value>)

      注意 -

      可以是*,節(jié)點(diǎn)或關(guān)系標(biāo)簽名稱或?qū)傩悦Q。

      示例

      MATCH (e:Employee) RETURN COUNT(*)

      MAX

      它采用一組行和節(jié)點(diǎn)或關(guān)系的作為輸入,并從給定行的give 列中查找最小值。

      函數(shù)語(yǔ)法

      MAX(<property-name> )

      MIN

      它采用一組行和節(jié)點(diǎn)或關(guān)系的作為輸入,并從給定行的give 列中查找最小值。

      函數(shù)語(yǔ)法

      MIN(<property-name> )

      注意 -

      應(yīng)該是節(jié)點(diǎn)或關(guān)系的名稱。

      讓我們用一個(gè)例子看看MAX和MIN的功能。

      示例

      MATCH (e:Employee) RETURN MAX(e.sal),MIN(e.sal)

      AVG

      它采用一組行和節(jié)點(diǎn)或關(guān)系的作為輸入,并從給定行的give 列中查找平均值。

      函數(shù)的語(yǔ)法

      AVG(<property-name> )

      SUM

      它采用一組行和節(jié)點(diǎn)或關(guān)系的作為輸入,并從給定行的give 列中查找求和值。

      函數(shù)的語(yǔ)法

      SUM(<property-name> )

      讓我們用一個(gè)例子來(lái)檢查SUM和AVG函數(shù)。

      MATCH (e:Employee) RETURN SUM(e.sal),AVG(e.sal)

      此命令從數(shù)據(jù)庫(kù)中可用的所有Employee節(jié)點(diǎn)查找總和平均值.

      3.關(guān)系函數(shù)

      Neo4j CQL提供了一組關(guān)系函數(shù),以在獲取開始節(jié)點(diǎn),結(jié)束節(jié)點(diǎn)等細(xì)節(jié)時(shí)知道關(guān)系的細(xì)節(jié)。

      關(guān)系函數(shù)列表

      S.No.

      功能

      描述

      1。

      STARTNODE

      它用于知道關(guān)系的開始節(jié)點(diǎn)。

      2。

      ENDNODE

      它用于知道關(guān)系的結(jié)束節(jié)點(diǎn)。

      3。

      ID

      它用于知道關(guān)系的ID。

      4。

      TYPE

      它用于知道字符串表示中的一個(gè)關(guān)系的TYPE。

      現(xiàn)在我們將通過(guò)示例詳細(xì)討論每個(gè)Neo4j CQL關(guān)系函數(shù)

      STARTNODE

      它需要一個(gè)字符串作為輸入并轉(zhuǎn)換為大寫字母。 所有CQL函數(shù)應(yīng)使用“()”括號(hào)。

      函數(shù)語(yǔ)法

      STARTNODE (<relationship-label-name>)

      注意:-

      可以是來(lái)自Neo4j數(shù)據(jù)庫(kù)的節(jié)點(diǎn)或關(guān)系的屬性名稱。

      示例

      MATCH (a)-[movie:ACTION_MOVIES]->(b) RETURN STARTNODE(movie)

      ENDNODE

      MATCH (a)-[movie:ACTION_MOVIES]->(b) RETURN ENDNODE(movie)

      ID TYPE

      MATCH (a)-[movie:ACTION_MOVIES]->(b) RETURN ID(movie),TYPE(movie)

      第七章:管理員

      1.數(shù)據(jù)庫(kù)備份

      在對(duì)Neo4j數(shù)據(jù)進(jìn)行備份、還原、遷移的操作時(shí),首先要關(guān)閉neo4j;

      cd %NEO4J_HOME%/bin
      ./neo4j stop

      數(shù)據(jù)備份到文件

      ./neo4j-admin  dump --database=graph.db --to=/home/2018.dump

      之后,進(jìn)行數(shù)據(jù)還原,將生成的存儲(chǔ)文件拷貝到另一個(gè)相同版本的環(huán)境中。

      2.數(shù)據(jù)庫(kù)恢復(fù)

      還原、遷移之前 ,關(guān)閉neo4j服務(wù)。操作同上;

      數(shù)據(jù)導(dǎo)入:

      ./neo4j-admin load --from=/home/2016-10-02.dump --database=graph.db --force

      重啟服務(wù):

      ./neo4j start

      第八章:Spring Data Neo4j

      1.簡(jiǎn)單介紹

      Neo4j提供JAVA API以編程方式執(zhí)行所有數(shù)據(jù)庫(kù)操作。

      具體Neo4j如何在原生Java程序編程,以及與Spring的集成,本章暫不討論。

      Spring數(shù)據(jù)模塊的優(yōu)點(diǎn):

      • 消除DAO層中的boiler plate代碼

      • DAO層中的工件少

      • 易于開發(fā)和維護(hù)

      • 改進(jìn)開發(fā)過(guò)程

      Spring數(shù)據(jù)模塊功能:

      • 支持基于XML的實(shí)體映射

      • 支持基于注釋的實(shí)體映射

      • 支持分頁(yè)

      • 支持事務(wù)

      • 更少的DAO層工件 - 實(shí)現(xiàn)存儲(chǔ)庫(kù)

      Spring DATA Neo4j模塊具有與上述相同的優(yōu)點(diǎn)和特點(diǎn)。

      接下來(lái),我們將基于Spring Boot在IDEA上開發(fā)Neo4j應(yīng)用程序,需要注意的是Springboot的版本

      2.新建項(xiàng)目

      我們選擇web和Neo4j兩個(gè)依賴即可,這里有必要說(shuō)一下,如果你是使用Spring boot2.0以上,在你創(chuàng)建項(xiàng)目完成后,啟動(dòng)程序會(huì)報(bào)錯(cuò):

      Caused by: java.lang.ClassNotFoundException: org.neo4j.ogm.drivers.http.driver.HttpDriver at java.net.URLClassLoader.findClass(URLClassLoader.java:381) ~[na:1.8.0_111] at java.lang.ClassLoader.loadClass(ClassLoader.java:424) ~[na:1.8.0_111] at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:331) ~[na:1.8.0_111] at java.lang.ClassLoader.loadClass(ClassLoader.java:357) ~[na:1.8.0_111] at java.lang.Class.forName0(Native Method) ~[na:1.8.0_111] at java.lang.Class.forName(Class.java:264) ~[na:1.8.0_111] at org.neo4j.ogm.session.SessionFactory.newDriverInstance(SessionFactory.java:92) ~[neo4j-ogm-core-3.1.0.jar:3.1.0] ... 45 common frames omitted

      原因是缺少依賴,解決方法是導(dǎo)入缺少的依賴:

      <dependency>            <groupId>org.neo4j</groupId>            <artifactId>neo4j-ogm-http-driver</artifactId>        </dependency>

      如果你的Spring boot版本為1.5.x,那么你只需要spring-data-neo4j即可:

      <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-neo4j</artifactId> </dependency>

      3.節(jié)點(diǎn)與關(guān)系

      新建節(jié)點(diǎn)類,id的屬性為Long而不能為long,還需要注意的是在Spring boot1.5中修飾id屬性的注釋為@GraphId,org.neo4j.ogm.annotation.Id不存在,效果一樣,都是Neo4j數(shù)據(jù)庫(kù)自動(dòng)創(chuàng)建的ID值。

      @NodeEntity(label = 'Bot')public class BotNode {    @Id    @GeneratedValue    private Long id; //id    @Property(name = 'name')    private String name;//名    @Property(name = 'kind')    private String kind;//類    @Property(name = 'weight')    private long weight;//權(quán)重    public BotNode() {    }    public BotNode(Long id, String name, String kind, long weight) {        this.id = id;        this.name = name;        this.kind = kind;        this.weight = weight;    }    public Long getId() {        return id;    }    public void setId(Long id) {        this.id = id;    }    public String getName() {        return name;    }    public void setName(String name) {        this.name = name;    }    public String getKind() {        return kind;    }    public void setKind(String kind) {        this.kind = kind;    }    public long getWeight() {        return weight;    }    public void setWeight(long weight) {        this.weight = weight;    }    @Override    public String toString() {        return 'BotNode{' +                'id=' + id +                ', name='' + name + '\'' +                ', kind='' + kind + '\'' +                ', weight=' + weight +                '}';    }}

      新建節(jié)點(diǎn)關(guān)系類

      有必要說(shuō)明一下, @StartNode@EndNode注釋的類可以不是同一個(gè)類。

      @RelationshipEntity(type = 'BotRelation')public class BotRelation { @Id @GeneratedValue private Long id; @StartNode private BotNode startNode; @EndNode private BotNode endNode; @Property private String relation; public BotRelation() { } public BotRelation(Long id, BotNode startNode, BotNode endNode, String relation) { this.id = id; this.startNode = startNode; this.endNode = endNode; this.relation = relation; } public String getRelation() { return relation; } public void setRelation(String relation) { this.relation = relation; } public Long getId() { return id; } public void setId(Long id) { this.id = id; } public BotNode getStartNode() { return startNode; } public void setStartNode(BotNode startNode) { this.startNode = startNode; } public BotNode getEndNode() { return endNode; } public void setEndNode(BotNode endNode) { this.endNode = endNode; } @Override public String toString() { return 'BotRelation{' + 'id=' + id + ', startNode=' + startNode + ', endNode=' + endNode + ', relation='' + relation + '\'' + '}'; }}

      4.Repository

      我們只需要使接口繼承Neo4jRepository就可以使用該接口提供的一些基礎(chǔ)的增刪改查方法。

      @Repositorypublic interface BotRepository extends Neo4jRepository<BotNode,Long> {    BotNode findAllByName(String name);}

      對(duì)于復(fù)雜的查詢我們可以參照上面講到的CQL語(yǔ)句執(zhí)行。

      @Repositorypublic interface BotRelationRepository extends Neo4jRepository<BotRelation,Long> { //返回節(jié)點(diǎn)n以及n指向的所有節(jié)點(diǎn)與關(guān)系 @Query('MATCH p=(n:Bot)-[r:BotRelation]->(m:Bot) WHERE id(n)={0} RETURN p') List<BotRelation> findAllByBotNode(BotNode botNode); //返回節(jié)點(diǎn)n以及n指向或指向n的所有節(jié)點(diǎn)與關(guān)系 @Query('MATCH p=(n:Bot)<-[r:BotRelation]->(m:Bot) WHERE m.name={name} RETURN p') List<BotRelation> findAllBySymptom(@Param('name') String name); //返回節(jié)點(diǎn)n以及n指向或指向n的所有節(jié)點(diǎn)以及這些節(jié)點(diǎn)間的所有關(guān)系 @Query('MATCH p=(n:Bot)<-[r:BotRelation]->(m:Bot)<-[:BotRelation]->(:Bot)<-[:BotRelation]->(n:Bot) WHERE n.name={name} RETURN p') List<BotRelation> findAllByStartNode(@Param('name') String name);}

      5.單元測(cè)試

      保存

      @RunWith(SpringRunner.class)@SpringBootTestpublic class Neo4jApplicationTests {    @Autowired    MovieRepository movieRepository;    @Test    public void contextLoads() {        movieRepository.save(new Movie('《奧特曼》'));        System.out.println(movieRepository.findAll());    }}

      查看打印:

      [Movie{id=8183, name='《奧特曼》'}]

      保存成功!

      補(bǔ)充

      如果想保存關(guān)系的話

      MedicalNode node = new MedicalNode(-1l,'節(jié)點(diǎn)','測(cè)試');medicalNodeRepository.save(node);MedicalNode node1 = new MedicalNode(-1l,'節(jié)點(diǎn)','測(cè)試');medicalNodeRepository.save(node1);medicalRelationRepository.save(new MedicalRelation(-1l,node,node1,'關(guān)系'));

      更新

      接下來(lái)我們測(cè)試更新數(shù)據(jù):

      @Test public void updata(){ Movie movie = movieRepository.findAllById(8183l); movie.setName('《迪迦》'); movieRepository.save(movie); System.out.println(movieRepository.findAll()); }

      執(zhí)行程序,報(bào)錯(cuò):

      java.lang.NullPointerException

      我們看到程序執(zhí)行的CQL語(yǔ)句為:

      MATCH (n:`Movie`) WHERE n.`id` = { `id_0` } WITH n RETURN n, ID(n)

      然后我們?cè)贜eo4j瀏覽器控制臺(tái)執(zhí)行查詢語(yǔ)句:

      這是為什么呢?在Neo4j中,根據(jù)Id查詢節(jié)點(diǎn)的語(yǔ)句為:

      MATCH (n:Movie) where id(n)=8183  RETURN n

      我們修改Repository層的查詢方法:

      @Repositorypublic interface MovieRepository extends Neo4jRepository<Movie, Long> { @Query('MATCH (n:Movie) where id(n)={id} RETURN n') Movie findAllById(@Param('id') Long id);}

      再次執(zhí)行更新程序,結(jié)果為:

      [Movie{id=8183, name='《迪迦》'}]

      更新成功!

      換句話說(shuō),只要掌握了CQL語(yǔ)句,就基本啥都會(huì)了~! 還有,本書并不代表全部的Neo4j知識(shí)。


      附錄 neo4j.conf漢化版

      For more details and a complete list of settings, please see https:///docs/operations-manual/current/reference/configuration-settings/# 如果想自定義neo4j數(shù)據(jù)庫(kù)數(shù)據(jù)的存儲(chǔ)路徑,要同時(shí)修改dbms.active_database 和 dbms.directories.data 兩項(xiàng)配置,# 修改配置后,數(shù)據(jù)會(huì)存放在${dbms.directories.data}/databases/${dbms.active_database} 目錄下# 安裝的數(shù)據(jù)庫(kù)的名稱,默認(rèn)使用${NEO4J_HOME}/data/databases/graph.db目錄# The name of the database to mount #dbms.active_database=graph.db#安裝Neo4j數(shù)據(jù)庫(kù)的各個(gè)配置路徑,默認(rèn)使用$NEO4J_HOME下的路徑#Paths of directories in the installation. # 數(shù)據(jù)路徑#dbms.directories.data=data # 插件路徑#dbms.directories.plugins=plugins #dbms.directories.certificates=certificates 證書路徑#dbms.directories.logs=logs 日志路徑#dbms.directories.lib=lib jar包路徑#dbms.directories.run=run 運(yùn)行路徑#默認(rèn)情況下想load csv文件,只能把csv文件放到${NEO4J_HOME}/import目錄下,把下面的#刪除后,可以在load csv時(shí)使用絕對(duì)路徑,這樣可能不安全#This setting constrains all `LOAD CSV` import files to be under the `import` directory. Remove or comment it out to allow files to be loaded from anywhere in the filesystem; this introduces possible security problems. See the `LOAD CSV` section of the manual for details. #此設(shè)置將所有“LOAD CSV”導(dǎo)入文件限制在`import`目錄下。刪除注釋允許從文件系統(tǒng)的任何地方加載文件;這引入了可能的安全問(wèn)題。dbms.directories.import=import#把下面這行的#刪掉后,連接neo4j數(shù)據(jù)庫(kù)時(shí)就不用輸密碼了#Whether requests to Neo4j are authenticated. 是否對(duì)Neo4j的請(qǐng)求進(jìn)行了身份驗(yàn)證。#To disable authentication, uncomment this line 要禁用身份驗(yàn)證,請(qǐng)取消注釋此行。#dbms.security.auth_enabled=false#Enable this to be able to upgrade a store from an older version. 是否兼容以前版本的數(shù)據(jù)dbms.allow_format_migration=true#Java Heap Size: by default the Java heap size is dynamically calculated based on available system resources. Java堆大?。耗J(rèn)情況下,Java堆大小是動(dòng)態(tài)地根據(jù)可用的系統(tǒng)資源計(jì)算。#Uncomment these lines to set specific initial and maximum heap size. 取消注釋這些行以設(shè)置特定的初始值和最大值#dbms.memory.heap.initial_size=512m#dbms.memory.heap.max_size=512m#The amount of memory to use for mapping the store files, in bytes (or kilobytes with the 'k' suffix, megabytes with 'm' and gigabytes with 'g'). 用于映射存儲(chǔ)文件的內(nèi)存量(以字節(jié)為單位)千字節(jié)帶有'k'后綴,兆字節(jié)帶有'm',千兆字節(jié)帶有'g')。#If Neo4j is running on a dedicated server, then it is generally recommended to leave about 2-4 gigabytes for the operating system, give the JVM enough heap to hold all your transaction state and query context, and then leave the rest for the page cache. 如果Neo4j在專用服務(wù)器上運(yùn)行,那么通常建議為操作系統(tǒng)保留大約2-4千兆字節(jié),為JVM提供足夠的堆來(lái)保存所有的事務(wù)狀態(tài)和查詢上下文,然后保留其余的頁(yè)面緩存 。#The default page cache memory assumes the machine is dedicated to running Neo4j, and is heuristically set to 50% of RAM minus the max Java heap size. 默認(rèn)頁(yè)面緩存存儲(chǔ)器假定機(jī)器專用于運(yùn)行Neo4j,并且試探性地設(shè)置為RAM的50%減去最大Java堆大小。#dbms.memory.pagecache.size=10g### Network connector configuration#With default configuration Neo4j only accepts local connections. Neo4j默認(rèn)只接受本地連接(localhost)#To accept non-local connections, uncomment this line: 要接受非本地連接,請(qǐng)取消注釋此行dbms.connectors.default_listen_address=0.0.0.0 (這是刪除#后的配置,可以通過(guò)ip訪問(wèn))#You can also choose a specific network interface, and configure a non-default port for each connector, by setting their individual listen_address. 還可以選擇特定的網(wǎng)絡(luò)接口,并配置非默認(rèn)值端口,設(shè)置它們各自的listen_address#The address at which this server can be reached by its clients. This may be the server's IP address or DNS name, or it may be the address of a reverse proxy which sits in front of the server. This setting may be overridden for individual connectors below. 客戶端可以訪問(wèn)此服務(wù)器的地址。這可以是服務(wù)器的IP地址或DNS名稱,或者可以是位于服務(wù)器前面的反向代理的地址。此設(shè)置可能會(huì)覆蓋以下各個(gè)連接器。#dbms.connectors.default_advertised_address=localhost#You can also choose a specific advertised hostname or IP address, and configure an advertised port for each connector, by setting their individual advertised_address. 您還可以選擇特定廣播主機(jī)名或IP地址,為每個(gè)連接器配置通告的端口,通過(guò)設(shè)置它們獨(dú)特的advertised_address。#Bolt connector 使用Bolt協(xié)議dbms.connector.bolt.enabled=truedbms.connector.bolt.tls_level=OPTIONALdbms.connector.bolt.listen_address=:7687#HTTP Connector. There must be exactly one HTTP connector. 使用http協(xié)議dbms.connector.http.enabled=truedbms.connector.http.listen_address=:7474#HTTPS Connector. There can be zero or one HTTPS connectors. 使用https協(xié)議dbms.connector.https.enabled=truedbms.connector.https.listen_address=:7473#Number of Neo4j worker threads. Neo4j線程數(shù)#dbms.threads.worker_count=#Logging configuration 日志配置#To enable HTTP logging, uncomment this line 要啟用HTTP日志記錄,請(qǐng)取消注釋此行dbms.logs.http.enabled=true#Number of HTTP logs to keep. 要保留的HTTP日志數(shù)#dbms.logs.http.rotation.keep_number=5#Size of each HTTP log that is kept. 每個(gè)HTTP日志文件的大小dbms.logs.http.rotation.size=20m#To enable GC Logging, uncomment this line 要啟用GC日志記錄,請(qǐng)取消注釋此行#dbms.logs.gc.enabled=true#GC Logging Options see http://docs.oracle.com/cd/E19957-01/819-0084-10/pt_tuningjava.html#wp57013 for more information. GC日志記錄選項(xiàng) 有關(guān)詳細(xì)信息,請(qǐng)參見http://docs.oracle.com/cd/E19957-01/819-0084-10/pt_tuningjava.html#wp57013#dbms.logs.gc.options=-XX:+PrintGCDetails -XX:+PrintGCDateStamps -XX:+PrintGCApplicationStoppedTime -XX:+PrintPromotionFailure -XX:+PrintTenuringDistribution#Number of GC logs to keep. 要保留的GC日志數(shù)#dbms.logs.gc.rotation.keep_number=5#Size of each GC log that is kept. 保留的每個(gè)GC日志文件的大小#dbms.logs.gc.rotation.size=20m#Size threshold for rotation of the debug log. If set to zero then no rotation will occur. Accepts a binary suffix 'k', 'm' or 'g'. 調(diào)試日志旋轉(zhuǎn)的大小閾值。如果設(shè)置為零,則不會(huì)發(fā)生滾動(dòng)(達(dá)到指定大小后切割日志文件)。接受二進(jìn)制后綴“k”,“m”或“g”。#dbms.logs.debug.rotation.size=20m#Maximum number of history files for the internal log. 最多保存幾個(gè)日志文件#dbms.logs.debug.rotation.keep_number=7### Miscellaneous configuration 其他配置#Enable this to specify a parser other than the default one. 啟用此選項(xiàng)可指定除默認(rèn)解析器之外的解析器#cypher.default_language_version=3.0#Determines if Cypher will allow using file URLs when loading data using `LOAD CSV`. Setting this value to `false` will cause Neo4j to fail `LOAD CSV` clauses that load data from the file system. 確定當(dāng)使用加載數(shù)據(jù)時(shí),Cypher是否允許使用文件URL `LOAD CSV`。將此值設(shè)置為`false`將導(dǎo)致Neo4j不能通過(guò)互聯(lián)網(wǎng)上的URL導(dǎo)入數(shù)據(jù),`LOAD CSV` 會(huì)從文件系統(tǒng)加載數(shù)據(jù)。dbms.security.allow_csv_import_from_file_urls=true#Retention policy for transaction logs needed to perform recovery and backups. 執(zhí)行恢復(fù)和備份所需的事務(wù)日志的保留策略#dbms.tx_log.rotation.retention_policy=7 days#Enable a remote shell server which Neo4j Shell clients can log in to. 啟用Neo4j Shell客戶端可以登錄的遠(yuǎn)程shell服務(wù)器dbms.shell.enabled=true#The network interface IP the shell will listen on (use 0.0.0.0 for all interfaces).dbms.shell.host=127.0.0.1#The port the shell will listen on, default is 1337.dbms.shell.port=1337#Only allow read operations from this Neo4j instance. This mode still requires write access to the directory for lock purposes. 只允許從Neo4j實(shí)例讀取操作。此模式仍然需要對(duì)目錄的寫訪問(wèn)以用于鎖定目的。#dbms.read_only=false#Comma separated list of JAX-RS packages containing JAX-RS resources, one package name for each mountpoint. The listed package names will be loaded under the mountpoints specified. Uncomment this line to mount the org.neo4j.examples.server.unmanaged.HelloWorldResource.java from neo4j-server-examples under /examples/unmanaged, resulting in a final URL of http://localhost:7474/examples/unmanaged/helloworld/{nodeId} 包含JAX-RS資源的JAX-RS軟件包的逗號(hào)分隔列表,每個(gè)安裝點(diǎn)一個(gè)軟件包名稱。所列出的軟件包名稱將在指定的安裝點(diǎn)下加載。取消注釋此行以裝載org.neo4j.examples.server.unmanaged.HelloWorldResource.java neo4j-server-examples下/ examples / unmanaged,最終的URL為http//localhost7474/examples/unmanaged/helloworld/{nodeId}#dbms.unmanaged_extension_classes=org.neo4j.examples.server.unmanaged=/examples/unmanaged#JVM Parameters JVM參數(shù)#G1GC generally strikes a good balance between throughput and tail latency, without too much tuning. G1GC通常在吞吐量和尾部延遲之間達(dá)到很好的平衡,而沒(méi)有太多的調(diào)整。dbms.jvm.additional=-XX:+UseG1GC#Have common exceptions keep producing stack traces, so they can be debugged regardless of how often logs are rotated. 有共同的異常保持生成堆棧跟蹤,所以他們可以被調(diào)試,無(wú)論日志被旋轉(zhuǎn)的頻率dbms.jvm.additional=-XX:-OmitStackTraceInFastThrow#Make sure that `initmemory` is not only allocated, but committed to the process, before starting the database. This reduces memory fragmentation, increasing the effectiveness of transparent huge pages. It also reduces the possibility of seeing performance drop due to heap-growing GC events, where a decrease in available page cache leads to an increase in mean IO response time. Try reducing the heap memory, if this flag degrades performance. 確保在啟動(dòng)數(shù)據(jù)庫(kù)之前,“initmemory”不僅被分配,而且被提交到進(jìn)程。這減少了內(nèi)存碎片,增加了透明大頁(yè)面的有效性。它還減少了由于堆增長(zhǎng)的GC事件而導(dǎo)致性能下降的可能性,其中可用頁(yè)面緩存的減少導(dǎo)致平均IO響應(yīng)時(shí)間的增加。如果此標(biāo)志降低性能,請(qǐng)減少堆內(nèi)存。 dbms.jvm.additional=-XX:+AlwaysPreTouch#Trust that non-static final fields are really final. This allows more optimizations and improves overall performance. NOTE: Disable this if you use embedded mode, or have extensions or dependencies that may use reflection or serialization to change the value of final fields! 信任非靜態(tài)final字段真的是final。這允許更多的優(yōu)化和提高整體性能。注意:如果使用嵌入模式,或者有可能使用反射或序列化更改最終字段的值的擴(kuò)展或依賴關(guān)系,請(qǐng)禁用此選項(xiàng)!dbms.jvm.additional=-XX:+UnlockExperimentalVMOptionsdbms.jvm.additional=-XX:+TrustFinalNonStaticFields#Disable explicit garbage collection, which is occasionally invoked by the JDK itself. 禁用顯式垃圾回收,這是偶爾由JDK本身調(diào)用。dbms.jvm.additional=-XX:+DisableExplicitGC#Remote JMX monitoring, uncomment and adjust the following lines as needed. Absolute paths to jmx.access and jmx.password files are required. 遠(yuǎn)程JMX監(jiān)視,取消注釋并根據(jù)需要調(diào)整以下行。需要jmx.access和jmx.password文件的絕對(duì)路徑。#Also make sure to update the jmx.access and jmx.password files with appropriate permission roles and passwords, the shipped configuration contains only a read only role called 'monitor' with password 'Neo4j'. 還要確保使用適當(dāng)?shù)臋?quán)限角色和密碼更新jmx.access和jmx.password文件,所配置的配置只包含名為“monitor”的只讀角色,密碼為“Neo4j”。#For more details, see: http://download.oracle.com/javase/8/docs/technotes/guides/management/agent.html On Unix based systems the jmx.password file needs to be owned by the user that will run the server, and have permissions set to 0600. Unix系統(tǒng),有關(guān)詳情,請(qǐng)參閱:http://download.oracle.com/javase/8/docs/technotes/guides/management/agent.html,jmx.password文件需要由運(yùn)行服務(wù)器的用戶擁有,并且權(quán)限設(shè)置為0600。#For details on setting these file permissions on Windows see: http://docs.oracle.com/javase/8/docs/technotes/guides/management/security-windows.html Windows系統(tǒng) 有關(guān)在設(shè)置這些文件權(quán)限的詳細(xì)信息,請(qǐng)參閱:http://docs.oracle.com/javase/8/docs/technotes/guides/management/security-windows.html#dbms.jvm.additional=-Dcom.sun.management.jmxremote.port=3637#dbms.jvm.additional=-Dcom.sun.management.jmxremote.authenticate=true#dbms.jvm.additional=-Dcom.sun.management.jmxremote.ssl=false#dbms.jvm.additional=-Dcom.sun.management.jmxremote.password.file=/absolute/path/to/conf/jmx.password#dbms.jvm.additional=-Dcom.sun.management.jmxremote.access.file=/absolute/path/to/conf/jmx.access#Some systems cannot discover host name automatically, and need this line configured: 某些系統(tǒng)無(wú)法自動(dòng)發(fā)現(xiàn)主機(jī)名,需要配置以下行:#dbms.jvm.additional=-Djava.rmi.server.hostname=$THE_NEO4J_SERVER_HOSTNAME#Expand Diffie Hellman (DH) key size from default 1024 to 2048 for DH-RSA cipher suites used in server TLS handshakes. 對(duì)于服務(wù)器TLS握手中使用的DH-RSA密碼套件,將Diffie Hellman(DH)密鑰大小從默認(rèn)1024展開到2048。#This is to protect the server from any potential passive eavesdropping. 這是為了保護(hù)服務(wù)器免受任何潛在的被動(dòng)竊聽。dbms.jvm.additional=-Djdk.tls.ephemeralDHKeySize=2048### Wrapper Windows NT/2000/XP Service Properties 包裝器Windows NT / 2000 / XP服務(wù)屬性包裝器Windows NT / 2000 / XP服務(wù)屬性#WARNING - Do not modify any of these properties when an application using this configuration file has been installed as a service. WARNING - 當(dāng)使用此配置文件的應(yīng)用程序已作為服務(wù)安裝時(shí),不要修改任何這些屬性。#Please uninstall the service before modifying this section. The service can then be reinstalled. 請(qǐng)?jiān)谛薷拇瞬糠种靶遁d服務(wù)。 然后可以重新安裝該服務(wù)。#Name of the service 服務(wù)的名稱dbms.windows_service_name=neo4j### Other Neo4j system properties 其他Neo4j系統(tǒng)屬性dbms.jvm.additional=-Dunsupported.dbms.udc.source=zip

        本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購(gòu)買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
        轉(zhuǎn)藏 分享 獻(xiàn)花(0

        0條評(píng)論

        發(fā)表

        請(qǐng)遵守用戶 評(píng)論公約

        類似文章 更多