1. 程式人生 > >Neo4j圖資料庫從入門到精通

Neo4j圖資料庫從入門到精通

目錄

  • 第一章:介紹
    • Neo4j是什麼
    • Neo4j的特點
    • Neo4j的優點
  • 第二章:安裝
    • 1.環境
    • 2.下載
    • 3.開啟遠端訪問
    • 4.啟動
  • 第三章:CQL
    • 1.CQL簡介
    • 2.Neo4j CQL命令/條款
    • 3.Neo4j CQL 函式
    • 4.Neo4j CQL資料型別
  • 第四章:命令
    • 1.CREATE建立
    • 2.MATCH查詢
    • 3.RETURN返回
    • 4.關係基礎
    • 5.WHERE子句
    • 6.DELETE刪除
    • 7.REMOVE刪除
    • 8.SET子句
    • 9.ORDER BY排序
    • 10.UNION子句
    • 11.LIMIT和SKIP子句
    • 12.MERGE命令
    • 13.NULL值
    • 14.IN操作符
    • 15.INDEX索引
    • 16.UNIQUE約束
    • 17.DISTINCT獨特
  • 第五章:解釋
    • 1.圖形字型
    • 2.ID屬性
    • 3.Caption標題
  • 第六章:函式
    • 1.字串函式
    • 2.AGGREGATION聚合
    • 3.關係函式
  • 第七章:管理員
    • 1.資料庫備份
    • 2.資料庫恢復
  • 第八章:Spring Data Neo4j
    • 1.簡單介紹
    • 2.新建專案
    • 3.節點與關係
    • 4.Repository
    • 5.單元測試
  • 附錄 neo4j.conf漢化釋義版

Create by [email protected] 2018-7-10

W3Cschool文件:https://www.w3cschool.cn/neo4j/neo4j_features_advantages.html

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

第一章:介紹

Neo4j是什麼

Neo4j是一個高效能的,NOSQL圖形資料庫,它將結構化資料儲存在網路上而不是表中。它是一個嵌入式的、基於磁碟的、具備完全的事務特性的Java持久化引擎,但是它將結構化資料儲存在網路(從數學角度叫做圖)上而不是表中。Neo4j也可以被看作是一個高效能的圖引擎,該引擎具有成熟資料庫的所有特性。程式設計師工作在一個面向物件的、靈活的網路結構下而不是嚴格、靜態的表中——但是他們可以享受到具備完全的事務特性、企業級的資料庫的所有好處。

Neo4j的特點

  • SQL就像簡單的查詢語言Neo4j CQL
  • 它遵循屬性圖資料模型
  • 它通過使用Apache Lucence支援索引
  • 它支援UNIQUE約束
  • 它它包含一個用於執行CQL命令的UI:Neo4j資料瀏覽器
  • 它支援完整的ACID(原子性,一致性,隔離性和永續性)規則
  • 它採用原生圖形庫與本地GPE(圖形處理引擎)
  • 它支援查詢的資料匯出到JSON和XLS格式
  • 它提供了REST API,可以被任何程式語言(如Java,Spring,Scala等)訪問
  • 它提供了可以通過任何UI MVC框架(如Node JS)訪問的Java指令碼
  • 它支援兩種Java API:Cypher API和Native Java API來開發Java應用程式

Neo4j的優點

  • 它很容易表示連線的資料
  • 檢索/遍歷/導航更多的連線資料是非常容易和快速的
  • 它非常容易地表示半結構化資料
  • Neo4j CQL查詢語言命令是人性化的可讀格式,非常容易學習
  • 它使用簡單而強大的資料模型
  • 它不需要複雜的連線來檢索連線的/相關的資料,因為它很容易檢索它的相鄰節點或關係細節沒有連線或索引

第二章:安裝

1.環境

Centos 7.4

neo4j-community-3.4.1.tar.gz

2.下載

下載地址 https://neo4j.com/download/other-releases/

下載

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

解壓

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

3.開啟遠端訪問

一、對於3.0以前的版本

在安裝目錄的 $NEO4J_HOME/conf/neo4j.conf 檔案內,找到下面一行,將註釋#號去掉就可以了 #dbms.connector.https.address=localhost:7473 改為 dbms.connector.https.address=0.0.0.0:7473 這樣,遠端其他電腦可以用本機的IP或者域名後面跟上7474 埠就能開啟web介面了 如: https://:7473

當然,你的作業系統的防火牆也要確保開放了7474端口才行,防火牆怎樣開放請自行鍼對自己的作業系統查詢文件

二、對於3.1及以後的版本

在安裝目錄的 $NEO4J_HOME/conf/neo4j.conf 檔案內,找到下面一行,將註釋#號去掉就可以了 dbms.connectors.default_listen_address=0.0.0.0

4.啟動

在bin目錄下,執行命令:./neo4j start啟動,其他命令 { console | start | stop | restart | status }

訪問http://IP地址:7474/, 出現下圖即代表安裝成功,頂部的$輸入框用來執行下面的CQL語句。

第一次訪問需要修改密碼,預設的賬號密碼都為neo4j

第三章:CQL

1.CQL簡介

CQL代表Cypher查詢語言。 像Oracle資料庫具有查詢語言SQL,Neo4j具有CQL作為查詢語言。

Neo4j CQL -

  • 它是Neo4j圖形資料庫的查詢語言。
  • 它是一種宣告性模式匹配語言
  • 它遵循SQL語法。
  • 它的語法是非常簡單且人性化、可讀的格式。

如Oracle SQL -

  • Neo4j CQL 已命令來執行資料庫操作。
  • Neo4j CQL 支援多個子句像在哪裡,順序等,以非常簡單的方式編寫非常複雜的查詢。
  • NNeo4j CQL 支援一些功能,如字串,Aggregation.In 加入他們,它還支援一些關係功能。

2.Neo4j CQL命令/條款

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

S.No. CQL命令/條 用法
1。 CREATE 建立 建立節點,關係和屬性
2。 MATCH 匹配 檢索有關節點,關係和屬性資料
3。 RETURN 返回 返回查詢結果
4。 WHERE 哪裡 提供條件過濾檢索資料
5。 DELETE 刪除 刪除節點和關係
6。 REMOVE 移除 刪除節點和關係的屬性
7。 ORDER BY以…排序 排序檢索資料
8。 SET 組 新增或更新標籤

3.Neo4j CQL 函式

以下是常用的Neo4j CQL函式:

S.No. 定製列表功能 用法
1。 String 字串 它們用於使用String字面量。
2。 Aggregation 聚合 它們用於對CQL查詢結果執行一些聚合操作。
3。 Relationship 關係 他們用於獲取關係的細節,如startnode,endnode等。

我們將在後面的章節中詳細討論所有Neo4j CQL命令,子句和函式語法,用法和示例。

4.Neo4j CQL資料型別

這些資料型別與Java語言類似。 它們用於定義節點或關係的屬性

Neo4j CQL支援以下資料型別:

S.No. CQL資料型別 用法
1. boolean 用於表示布林文字:true,false。
2. byte 用於表示8位整數。
3. short 用於表示16位整數。
4. int 用於表示32位整數。
5. long 用於表示64位整數。
6. float I用於表示32位浮點數。
7. double 用於表示64位浮點數。
8. char 用於表示16位字元。
9. String 用於表示字串。

第四章:命令

1.CREATE建立

Neo4j CQL建立一個沒有屬性的節點

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

語法說明

規範說法是節點標籤名稱,其實相當於Mysql資料庫中的表名,而是節點名稱,其實代指建立的此行資料。

示例

CREATE (emp:Employee)

或者

CREATE (:Employee)

Neo4j CQL建立具有屬性的節點

Neo4j CQL“CREATE”命令用於建立帶有屬性的節點。 它建立一個具有一些屬性(鍵值對)的節點來儲存資料。

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

示例

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

建立多個標籤到節點

語法:

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

示例

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

2.MATCH查詢

Neo4j CQL MATCH命令用於

  • 從資料庫獲取有關節點和屬性的資料
  • 從資料庫獲取有關節點,關係和屬性的資料

MATCH命令語法:

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

示例

MATCH (dept:Dept)

但是執行後會報錯:

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

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

3.RETURN返回

Neo4j CQL RETURN子句用於 -

  • 檢索節點的某些屬性
  • 檢索節點的所有屬性
  • 檢索節點和關聯關係的某些屬性
  • 檢索節點和關聯關係的所有屬性

RETURN命令語法:

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.關係基礎

Neo4j圖資料庫遵循屬性圖模型來儲存和管理其資料。

根據屬性圖模型,關係應該是定向的。 否則,Neo4j將丟擲一個錯誤訊息。

基於方向性,Neo4j關係被分為兩種主要型別。

  • 單向關係
  • 雙向關係

使用新節點建立關係

示例

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

這句會建立節點e,節點c,以及e -> c的關係r,這裡需要注意方向,比如雙向是

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

使用已知節點建立帶屬性的關係:

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>

還是一系列鍵值對

示例

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

檢索關係節點的詳細資訊:

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子句來過濾MATCH查詢的結果。

簡單WHERE子句語法

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

語法說明:

S.No. 語法元素 描述
1 WHERE 它是一個Neo4j CQL關鍵字。
2 <屬性名稱> 它是節點或關係的屬性名稱。
3 <比較運算子> 它是Neo4j CQL比較運算子之一。
4 <值> 它是一個字面值,如數字文字,字串文字等。

Neo4j CQL中的比較運算子

Neo4j 支援以下的比較運算子,在 Neo4j CQL WHERE 子句中使用來支援條件

S.No. 布林運算子 描述
1. = 它是Neo4j CQL“等於”運算子。
2. <> 它是一個Neo4j CQL“不等於”運算子。
3. < 它是一個Neo4j CQL“小於”運算子。
4. > 它是一個Neo4j CQL“大於”運算子。
5. <= 它是一個Neo4j CQL“小於或等於”運算子。
6. = 它是一個Neo4j CQL“大於或等於”運算子。

我們可以使用布林運算子在同一命令上放置多個條件。

Neo4j CQL中的布林運算子

Neo4j支援以下布林運算子在Neo4j CQL WHERE子句中使用以支援多個條件。

S.No. 布林運算子 描述
1 AND 它是一個支援AND操作的Neo4j CQL關鍵字。
2 OR 它是一個Neo4j CQL關鍵字來支援OR操作。
3 NOT 它是一個Neo4j CQL關鍵字支援NOT操作。
4 XOR 它是一個支援XOR操作的Neo4j CQL關鍵字。

示例

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

利用WHERE建立指定關係節點:

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

有必要補充一下,可以不使用WHERE達到WHERE的一些效果,比如

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

6.DELETE刪除

Neo4j使用CQL DELETE子句

  • 刪除節點。
  • 刪除節點及相關節點和關係。

DELETE節點子句語法

DELETE <node-name-list>

示例

MATCH (e: Employee) DELETE e

DELETE節點和關係子句語法

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

示例

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

7.REMOVE刪除

有時基於我們的客戶端要求,我們需要向現有節點或關係新增或刪除屬性。

我們使用Neo4j CQL SET子句向現有節點或關係新增新屬性。

我們使用Neo4j CQL REMOVE子句來刪除節點或關係的現有屬性。

Neo4j CQL REMOVE命令用於

  • 刪除節點或關係的標籤
  • 刪除節點或關係的屬性

Neo4j CQL DELETE和REMOVE命令之間的主要區別 -

  • DELETE操作用於刪除節點和關聯關係。
  • REMOVE操作用於刪除標籤和屬性。

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

  • 這兩個命令不應單獨使用。
  • 兩個命令都應該與MATCH命令一起使用。

1.REMOVE屬性子句語法

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

語法說明:

S.No. 語法元素 描述
1。 它是節點的名稱。
2。 它是節點的屬性名稱。

示例

這裡我們可以觀察到DebitCard節點包含6個屬性。

在資料瀏覽器上鍵入以下命令刪除cvv屬性

MATCH (dc:DebitCard) 
REMOVE dc.cvv
RETURN dc

2.REMOVE一個Label子句語法:

REMOVE <label-name-list> 
S.No. 語法元素 描述
1. REMOVE 它是一個Neo4j CQL關鍵字。
2. 它是一個標籤列表,用於永久性地從節點或關係中刪除它。

語法

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

示例

1.我們建立一個含有兩個標籤的節點:

CREATE (m:Movie:Pic)

2.查詢該節點

MATCH (n:Movie) RETURN n

3.刪除標籤

MATCH (m:Movie) 
REMOVE m:Pic

4.再次查詢

8.SET子句

有時,根據我們的客戶端要求,我們需要向現有節點或關係新增新屬性。

要做到這一點,Neo4j CQL提供了一個SET子句。

Neo4j CQL已提供SET子句來執行以下操作。

  • 向現有節點或關係新增新屬性
  • 新增或更新屬性值

SET子句語法

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

語法說明:

S.No. 語法元素 描述
1 <節點標籤名稱> 這是一個節點的標籤名稱。
2 <屬性名稱> 它是一個節點的屬性名。

示例

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

9.ORDER BY排序

Neo4j CQL ORDER BY子句

Neo4j CQL在MATCH命令中提供了“ORDER BY”子句,對MATCH查詢返回的結果進行排序。

我們可以按升序或降序對行進行排序。

預設情況下,它按升序對行進行排序。 如果我們要按降序對它們進行排序,我們需要使用DESC子句。

ORDER BY子句語法

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

語法:

<node-label-name>.<property1-name>,
<node-label-name>.<property2-name>, 
.... 
<node-label-name>.<propertyn-name> 
S.No. 語法元素 描述
1。 它是節點的標籤名稱。
2。 它是節點的屬性名稱。

示例

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

10.UNION子句

與SQL一樣,Neo4j CQL有兩個子句,將兩個不同的結果合併成一組結果

  • UNION
  • UNION ALL

UNION子句

它將兩組結果中的公共行組合並返回到一組結果中。 它不從兩個節點返回重複的行。

限制:

結果列型別和來自兩組結果的名稱必須匹配,這意味著列名稱應該相同,列的資料型別應該相同。

UNION子句語法

<MATCH Command1>
   UNION
<MATCH Command2>
S.No. 語法元素 描述
1。 它是CQL MATCH命令,由UNION子句使用。
2。 它是CQL MATCH命令兩個由UNION子句使用。
3。 UNION 它是UNION子句的Neo4j CQL關鍵字。

注意 -

如果這兩個查詢不返回相同的列名和資料型別,那麼它丟擲一個錯誤。

示例

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

UNION ALL子句

它結合並返回兩個結果集的所有行成一個單一的結果集。它還返回由兩個節點重複行。

限制

結果列型別,並從兩個結果集的名字必須匹配,這意味著列名稱應該是相同的,列的資料型別應該是相同的。

UNION ALL子句語法

<MATCH Command1>
UNION ALL
<MATCH Command2>

示例

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

11.LIMIT和SKIP子句

Neo4j CQL已提供LIMIT子句和SKIP來過濾或限制查詢返回的行數。

簡單來說:LIMIT返回前幾行,SKIP返回後幾行。

LIMIT 示例

MATCH (emp:Employee) 
RETURN emp
LIMIT 2

它只返回Top的兩個結果,因為我們定義了limit = 2。這意味著前兩行。

SKIP示例

MATCH (emp:Employee) 
RETURN emp
SKIP 2

它只返回來自Bottom的兩個結果,因為我們定義了skip = 2。這意味著最後兩行。

12.MERGE命令

Neo4j使用CQL MERGE命令 -

  • 建立節點,關係和屬性
  • 為從資料庫檢索資料

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

MERGE = CREATE + MATCH

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

如果它不存在於圖中,則它建立新的節點/關係並返回結果。

Neo4j CQL MERGE語法

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

注意 -

Neo4j CQL MERGE命令語法與CQL CREATE命令類似。

我們將使用這兩個命令執行以下操作 -

  • 建立具有一個屬性的配置檔案節點:Id,名稱
  • 建立具有相同屬性的同一個Profile節點:Id,Name
  • 檢索所有Profile節點詳細資訊並觀察結果

我們將使用CREATE命令執行這些操作:

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

如果我們觀察上面的查詢結果,它只顯示一行,因為CQL MERGE命令檢查該節點在資料庫中是否可用。 如果它不存在,它建立新節點。 否則,它不建立新的。

通過觀察這些結果,我們可以說,CQL MERGE命令將新的節點新增到資料庫,只有當它不存在。

13.NULL值

Neo4j CQL將空值視為對節點或關係的屬性的缺失值或未定義值。

當我們建立一個具有現有節點標籤名稱但未指定其屬性值的節點時,它將建立一個具有NULL屬性值的新節點。

讓我們用一個例子來看這個。

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

提供了一個WHERE子句來過濾該行,即Id屬性不應該包含NULL值。

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

這裡我們使用IS操作符來僅返回NULL行。

14.IN操作符

與SQL一樣,Neo4j CQL提供了一個IN運算子,以便為CQL命令提供值的集合。

IN操作符語法

IN[<Collection-of-values>]

它是由逗號運算子分隔的值的集合。

示例

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

15.INDEX索引

Neo4j SQL支援節點或關係屬性上的索引,以提高應用程式的效能。

我們可以為具有相同標籤名稱的所有節點的屬性建立索引。

我們可以在MATCH或WHERE或IN運算子上使用這些索引列來改進CQL Command的執行。

Neo4J索引操作

  • Create Index 建立索引
  • Drop Index 丟棄索引

我們將在本章中用示例來討論這些操作。

建立索引的語法:

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

注意:

冒號(:)運算子用於引用節點或關係標籤名稱。

上述語法描述它在節點或關係的的上建立一個新索引。

示例

CREATE INDEX ON :Customer (name)

刪除索引的語法:

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

示例

DROP INDEX ON :Customer (name)

16.UNIQUE約束

在Neo4j資料庫中,CQL CREATE命令始終建立新的節點或關係,這意味著即使您使用相同的值,它也會插入一個新行。 根據我們對某些節點或關係的應用需求,我們必須避免這種重複。 然後我們不能直接得到這個。 我們應該使用一些資料庫約束來建立節點或關係的一個或多個屬性的規則。

像SQL一樣,Neo4j資料庫也支援對NODE或Relationship的屬性的UNIQUE約束

UNIQUE約束的優點

  • 避免重複記錄。
  • 強制執行資料完整性規則

建立唯一約束語法

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

語法說明:

S.No. 語法元素 描述
1。 CREATE CONSTRAINT ON 它是一個Neo4j CQL關鍵字。
2。 它是節點或關係的標籤名稱。
3。 ASSERT 它是一個Neo4j CQL關鍵字。
4。 它是節點或關係的屬性名稱。
5。 IS UNIQUE 它是一個Neo4j CQL關鍵字,通知Neo4j資料庫伺服器建立一個唯一約束。

注意:

上述語法描述了只需要 節點或關係就可以創造一個獨特的約束。

示例

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

注意

如果建立約束時節點屬性有重複值,Neo4j DB伺服器將會丟擲一個錯誤,表示無法建立。

刪除UNIQUE約束語法:

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

示例

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

17.DISTINCT獨特

這個函式的用法就像SQL中的distinct關鍵字,返回的是所有不同值。

示例

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

返回的是

第五章:解釋

1.圖形字型

關於Neo4j提供的圖形瀏覽器,我們可以從其中檢視節點的屬性,或者改變其中的節點的大小顏色。


2.ID屬性

在Neo4j中,“Id”是節點和關係的預設內部屬性。 這意味著,當我們建立一個新的節點或關係時,Neo4j資料庫伺服器將為內部使用分配一個數字。 它會自動遞增。

我們從一個例子去看:

新增一個節點

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

檢視該節點

MATCH (n:Tweet) RETURN n 

3.Caption標題

所謂的Caption標題,就是更改Neo4j瀏覽器的節點顯示的文字(圓圈內部)。比如

我們點選下圖所示:

圓圈內部變為了id值。

第六章:函式

1.字串函式

與SQL一樣,Neo4J CQL提供了一組String函式,用於在CQL查詢中獲取所需的結果。

這裡我們將討論一些重要的和經常使用的功能。

字串函式列表

S.No. 功能 描述
1。 UPPER 它用於將所有字母更改為大寫字母。
2。 LOWER 它用於將所有字母改為小寫字母。
3。 SUBSTRING 它用於獲取給定String的子字串。
4。 REPLACE 它用於替換一個字串的子字串。

注意:所有CQL函式應使用“()”括號。

現在我們將通過示例詳細討論每個Neo4J CQL字串函式

1.UPPER

它需要一個字串作為輸入並轉換為大寫字母。 所有CQL函式應使用“()”括號。

函式語法

UPPER (<input-string>)

注意:

可以是來自Neo4J資料庫的節點或關係的屬性名稱。

示例

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

2.LOWER

它需要一個字串作為輸入並轉換為小寫字母。 所有CQL函式應使用“()”括號。

函式語法

LOWER (<input-string>)

注意:

可以是來自Neo4J資料庫的節點或關係的屬性名稱

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

3.SUBSTRING

它接受一個字串作為輸入和兩個索引:一個是索引的開始,另一個是索引的結束,並返回從StartInded到EndIndex-1的子字串。 所有CQL函式應使用“()”括號。

函式的語法

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

注意:

在Neo4J CQL中,如果一個字串包含n個字母,則它的長度為n,索引從0開始,到n-1結束。

是SUBSTRING函式的索引值。

是可選的。 如果我們省略它,那麼它返回給定字串的子串從startIndex到字串的結尾。

示例

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

2.AGGREGATION聚合

和SQL一樣,Neo4j CQL提供了一些在RETURN子句中使用的聚合函式。 它類似於SQL中的GROUP BY子句。

我們可以使用MATCH命令中的RETURN +聚合函式來處理一組節點並返回一些聚合值。

聚合函式列表

S.No. 聚集功能 描述
1。 COUNT 它返回由MATCH命令返回的行數。
2。 MAX 它從MATCH命令返回的一組行返回最大值。
3。 MIN 它返回由MATCH命令返回的一組行的最小值。
4。 SUM 它返回由MATCH命令返回的所有行的求和值。
5。 AVG 它返回由MATCH命令返回的所有行的平均值。

現在我們將通過示例詳細討論每個Neo4j CQL AGGREGATION函式

計數

它從MATCH子句獲取結果,並計算結果中出現的行數,並返回該計數值。 所有CQL函式應使用“()”括號。

函式語法

COUNT(<value>)

注意 -

可以是*,節點或關係標籤名稱或屬性名稱。

示例

MATCH (e:Employee) RETURN COUNT(*)

MAX

它採用一組行和節點或關係的作為輸入,並從給定行的give 列中查詢最小值。

函式語法

MAX(<property-name> )

MIN

它採用一組行和節點或關係的作為輸入,並從給定行的give 列中查詢最小值。

函式語法

MIN(<property-name> )

注意 -

應該是節點或關係的名稱。

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

示例

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

AVG

它採用一組行和節點或關係的作為輸入,並從給定行的give 列中查詢平均值。

函式的語法

AVG(<property-name> )

SUM

它採用一組行和節點或關係的作為輸入,並從給定行的give 列中查詢求和值。

函式的語法

SUM(<property-name> )

讓我們用一個例子來檢查SUM和AVG函式。

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

此命令從資料庫中可用的所有Employee節點查詢總和平均值.

3.關係函式

Neo4j CQL提供了一組關係函式,以在獲取開始節點,結束節點等細節時知道關係的細節。

關係函式列表

S.No. 功能 描述
1。 STARTNODE 它用於知道關係的開始節點。
2。 ENDNODE 它用於知道關係的結束節點。
3。 ID 它用於知道關係的ID。
4。 TYPE 它用於知道字串表示中的一個關係的TYPE。

現在我們將通過示例詳細討論每個Neo4j CQL關係函式

STARTNODE

它需要一個字串作為輸入並轉換為大寫字母。 所有CQL函式應使用“()”括號。

函式語法

STARTNODE (<relationship-label-name>)

注意:

可以是來自Neo4j資料庫的節點或關係的屬性名稱。

示例

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.資料庫備份

在對Neo4j資料進行備份、還原、遷移的操作時,首先要關閉neo4j;

cd %NEO4J_HOME%/bin
./neo4j stop

資料備份到檔案

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

之後,進行資料還原,將生成的儲存檔案拷貝到另一個相同版本的環境中。

2.資料庫恢復

還原、遷移之前 ,關閉neo4j服務。操作同上;

資料匯入:

./neo4j-admin load --from=/home/2018.dump --database=graph.db --force

重啟服務:

./neo4j start

第八章:Spring Data Neo4j

1.簡單介紹

Neo4j提供JAVA API以程式設計方式執行所有資料庫操作。

具體Neo4j如何在原生Java程式程式設計,以及與Spring的整合,本章暫不討論。

Spring資料模組的優點:

  • 消除DAO層中的boiler plate程式碼
  • DAO層中的工件少
  • 易於開發和維護
  • 改進開發過程

Spring資料模組功能:

  • 支援基於XML的實體對映
  • 支援基於註釋的實體對映
  • 支援分頁
  • 支援事務
  • 更少的DAO層工件 - 實現儲存庫

Spring DATA Neo4j模組具有與上述相同的優點和特點。

接下來,我們將基於Spring Boot在IDEA上開發Neo4j應用程式,需要注意的是Springboot的版本

2.新建專案

我們選擇web和Neo4j兩個依賴即可,這裡有必要說一下,如果你是使用Spring boot2.0以上,在你建立專案完成後,啟動程式會報錯:

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

原因是缺少依賴,解決方法是匯入缺少的依賴:

        <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.節點與關係

新建節點類,id的屬性為Long而不能為long,還需要注意的是在Spring boot1.5中修飾id屬性的註釋為@GraphIdorg.neo4j.ogm.annotation.Id不存在,效果一樣,都是Neo4j資料庫自動建立的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;//權重

    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 +
                '}';
    }

}

新建節點關係類

有必要說明一下, @StartNode@EndNode註釋的類可以不是同一個類。

@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就可以使用該介面提供的一些基礎的增刪改查方法。

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

}

對於複雜的查詢我們可以參照上面講到的CQL語句執行。

@Repository
public interface BotRelationRepository extends Neo4jRepository<BotRelation,Long> {
    //返回節點n以及n指向的所有節點與關係
    @Query("MATCH p=(n:Bot)-[r:BotRelation]->(m:Bot) WHERE id(n)={0} RETURN p")
    List<BotRelation> findAllByBotNode(BotNode botNode);

    //返回節點n以及n指向或指向n的所有節點與關係
    @Query("MATCH p=(n:Bot)<-[r:BotRelation]->(m:Bot) WHERE m.name={name} RETURN p")
    List<BotRelation> findAllBySymptom(@Param("name") String name);

    //返回節點n以及n指向或指向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.單元測試

儲存

@RunWith(SpringRunner.class)
@SpringBootTest
public class Neo4jApplicationTests {
    @Autowired
    MovieRepository movieRepository;

    @Test
    public void contextLoads() {
        movieRepository.save(new Movie("《奧特曼》"));
        System.out.println(movieRepository.findAll());
    }

}

檢視列印:

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

儲存成功!

補充

如果想儲存關係的話

MedicalNode node = new MedicalNode(-1l,"節點","測試");
medicalNodeRepository.save(node);
MedicalNode node1 = new MedicalNode(-1l,"節點","測試");
medicalNodeRepository.save(node1);
medicalRelationRepository.save(new MedicalRelation(-1l,node,node1,"關係"));

  

更新

接下來我們測試更新資料:

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

執行程式,報錯:

java.lang.NullPointerException

我們看到程式執行的CQL語句為:

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

然後我們在Neo4j瀏覽器控制檯執行查詢語句:

這是為什麼呢?在Neo4j中,根據Id查詢節點的語句為:

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

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

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

再次執行更新程式,結果為:

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

更新成功!

換句話說,只要掌握了CQL語句,就基本啥都會了~!

還有,本書並不代表全部的Neo4j知識。

附錄 neo4j.conf漢化釋義版

# For more details and a complete list of settings, please see https://neo4j.com/docs/operations-manual/current/reference/configuration-settings/

# 如果想自定義neo4j資料庫資料的儲存路徑,要同時修改dbms.active_database 和 dbms.directories.data 兩項配置,
# 修改配置後,資料會存放在${dbms.directories.data}/databases/${dbms.active_database} 目錄下
# 安裝的資料庫的名稱,預設使用${NEO4J_HOME}/data/databases/graph.db目錄
# The name of the database to mount  
#dbms.active_database=graph.db

#安裝Neo4j資料庫的各個配置路徑,預設使用$NEO4J_HOME下的路徑
#Paths of directories in the installation. 
# 資料路徑
#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 執行路徑

#預設情況下想load csv檔案,只能把csv檔案放到${NEO4J_HOME}/import目錄下,把下面的#刪除後,可以在load csv時使用絕對路徑,這樣可能不安全
#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.  
#此設定將所有“LOAD CSV”匯入檔案限制在`import`目錄下。刪除註釋允許從檔案系統的任何地方載入檔案;這引入了可能的安全問題。
dbms.directories.import=import

#把下面這行的#刪掉後,連線neo4j資料庫時就不用輸密碼了
#Whether requests to Neo4j are authenticated. 是否對Neo4j的請求進行了身份驗證。
#To disable authentication, uncomment this line 要禁用身份驗證,請取消註釋此行。
#dbms.security.auth_enabled=false

#Enable this to be able to upgrade a store from an older version. 是否相容以前版本的資料
dbms.allow_format_migration=true

#Java Heap Size: by default the Java heap size is dynamically calculated based on available system resources. Java堆大小:預設情況下,Java堆大小是動態地根據可用的系統資源計算。
#Uncomment these lines to set specific initial and maximum heap size. 取消註釋這些行以設定特定的初始值和最大值
#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'). 用於對映儲存檔案的記憶體量(以位元組為單位)千位元組帶有'k'字尾,兆位元組帶有'm',千兆位元組帶有'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在專用伺服器上執行,那麼通常建議為作業系統保留大約2-4千兆位元組,為JVM提供足夠的堆來儲存所有的事務狀態和查詢上下文,然後保留其餘的頁面快取 。
#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.  預設頁面快取儲存器假定機器專用於執行Neo4j,並且試探性地設定為RAM的50%減去最大Java堆大小。
#dbms.memory.pagecache.size=10g


### Network connector configuration

#With default configuration Neo4j only accepts local connections. Neo4j預設只接受本地連線(localhost)
#To accept non-local connections, uncomment this line:  要接受非本地連線,請取消註釋此行
dbms.connectors.default_listen_address=0.0.0.0 (這是刪除#後的配置,可以通過ip訪問)

#You can also choose a specific network interface, and configure a non-default port for each connector, by setting their individual listen_address. 還可以選擇特定的網路介面,並配置非預設值埠,設定它們各自的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. 客戶端可以訪問此伺服器的地址。這可以是伺服器的IP地址或DNS名稱,或者可以是位於伺服器前面的反向代理的地址。此設定可能會覆蓋以下各個聯結器。
#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. 您還可以選擇特定廣播主機名或IP地址,
為每個聯結器配置通告的埠,通過設定它們獨特的advertised_address。

#Bolt connector 使用Bolt協議
dbms.connector.bolt.enabled=true
dbms.connector.bolt.tls_level=OPTIONAL
dbms.connector.bolt.listen_address=:7687

#HTTP Connector. There must be exactly one HTTP connector. 使用http協議
dbms.connector.http.enabled=true
dbms.connector.http.listen_address=:7474

#HTTPS Connector. There can be zero or one HTTPS connectors. 使用https協議
dbms.connector.https.enabled=true
dbms.connector.https.listen_address=:7473

#Number of Neo4j worker threads. Neo4j執行緒數
#dbms.threads.worker_count=


#Logging configuration  日誌配置

#To enable HTTP logging, uncomment this line  要啟用HTTP日誌記錄,請取消註釋此行
dbms.logs.http.enabled=true

#Number of HTTP logs to keep. 要保留的HTTP日誌數
#dbms.logs.http.rotation.keep_number=5

#Size of each HTTP log that is kept. 每個HTTP日誌檔案的大小
dbms.logs.http.rotation.size=20m

#To enable GC Logging, uncomment this line 要啟用GC日誌記錄,請取消註釋此行
#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日誌記錄選項 有關詳細資訊,請參見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日誌數
#dbms.logs.gc.rotation.keep_number=5

#Size of each GC log that is kept. 保留的每個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".  除錯日誌旋轉的大小閾值。如果設定為零,則不會發生滾動(達到指定大小後切割日誌檔案)。接受二進位制字尾“k”,“m”或“g”。
#dbms.logs.debug.rotation.size=20m

#Maximum number of history files for the internal log. 最多儲存幾個日誌檔案
#dbms.logs.debug.rotation.keep_number=7


### Miscellaneous configuration  其他配置


#Enable this to specify a parser other than the default one. 啟用此選項可指定除預設解析器之外的解析器
#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.    確定當使用載入資料時,Cypher是否允許使用檔案URL `LOAD CSV`。將此值設定為`false`將導致Neo4j不能通過網際網路上的URL匯入資料,`LOAD CSV` 會從檔案系統載入資料。
dbms.security.allow_csv_import_from_file_urls=true

#Retention policy for transaction logs needed to perform recovery and backups.  執行恢復和備份所需的事務日誌的保留策略
#dbms.tx_log.rotation.retention_policy=7 days

#Enable a remote shell server which Neo4j Shell clients can log in to.  啟用Neo4j Shell客戶端可以登入的遠端shell伺服器
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例項讀取操作。此模式仍然需要對目錄的寫訪問以用於鎖定目的。
#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軟體包的逗號分隔列表,每個安裝點一個軟體包名稱。所列出的軟體包名稱將在指定的安裝點下載入。取消註釋此行以裝載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引數

#G1GC generally strikes a good balance between throughput and tail latency, without too much tuning. G1GC通常在吞吐量和尾部延遲之間達到很好的平衡,而沒有太多的調整。
dbms.jvm.additional=-XX:+UseG1GC

#Have common exceptions keep producing stack traces, so they can be debugged regardless of how often logs are rotated. 有共同的異常保持生成堆疊跟蹤,所以他們可以被除錯,無論日誌被旋轉的頻率
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.    確保在啟動資料庫之前,“initmemory”不僅被分配,而且被提交到程序。這減少了記憶體碎片,增加了透明大頁面的有效性。它還減少了由於堆增長的GC事件而導致效能下降的可能性,其中可用頁面快取的減少導致平均IO響應時間的增加。如果此標誌降低效能,請減少堆記憶體。    
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!    信任非靜態final欄位真的是final。這允許更多的優化和提高整體效能。注意:如果使用嵌入模式,或者有可能使用反射或序列化更改最終欄位的值的擴充套件或依賴關係,請禁用此選項!
dbms.jvm.additional=-XX:+UnlockExperimentalVMOptions
dbms.jvm.additional=-XX:+TrustFinalNonStaticFields

#Disable explicit garbage collection, which is occasionally invoked by the JDK itself.  禁用顯式垃圾回收,這是偶爾由JDK本身呼叫。
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.  遠端JMX監視,取消註釋並根據需要調整以下行。需要jmx.access和jmx.password檔案的絕對路徑。
#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'. 還要確保使用適當的許可權角色和密碼更新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系統,有關詳情,請參閱:http://download.oracle.com/javase/8/docs/technotes/guides/management/agent.html,jmx.password檔案需要由執行伺服器的使用者擁有,並且許可權設定為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系統  有關在設定這些檔案許可權的詳細資訊,請參閱: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:  某些系統無法自動發現主機名,需要配置以下行:
#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. 對於伺服器TLS握手中使用的DH-RSA密碼套件,將Diffie Hellman(DH)金鑰大小從預設1024展開到2048。
#This is to protect the server from any potential passive eavesdropping. 這是為了保護伺服器免受任何潛在的被動竊聽。
dbms.jvm.additional=-Djdk.tls.ephemeralDHKeySize=2048


### Wrapper Windows NT/2000/XP Service Properties  包裝器Windows NT / 2000 / XP服務屬性包裝器Windows NT / 2000 / XP服務屬性

#WARNING - Do not modify any of these properties when an application using this configuration file has been installed as a service.  WARNING - 當使用此配置檔案的應用程式已作為服務安裝時,不要修改任何這些屬性。
#Please uninstall the service before modifying this section.  The service can then be reinstalled. 請在修改此部分之前解除安裝服務。 然後