日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 综合教程 >内容正文

综合教程

史上最全面的Neo4j使用指南「建议收藏」(汉典史字的基本解释)

發布時間:2023/12/15 综合教程 34 生活家
生活随笔 收集整理的這篇文章主要介紹了 史上最全面的Neo4j使用指南「建议收藏」(汉典史字的基本解释) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

大家好,又見面了,我是你們的朋友風君子。如果您正在找激活碼,請點擊查看最新教程,關注關注公眾號 “全棧程序員社區” 獲取激活教程,可能之前舊版本教程已經失效.最新Idea2022.1教程親測有效,一鍵激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟無欺

Neo4j圖形數據庫教程

  • Create by yster@foxmail.com 2018-7-10
  • 我的博客:https://blog.csdn.net/yueshutong123
  • 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語句。

第三章: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/2016-10-02.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. 請在修改此部分之前卸載服務。 然后可以重新安裝該服務。
#Name of the service 服務的名稱
dbms.windows_service_name=neo4j
### Other Neo4j system properties  其他Neo4j系統屬性
dbms.jvm.additional=-Dunsupported.dbms.udc.source=zip

總結

以上是生活随笔為你收集整理的史上最全面的Neo4j使用指南「建议收藏」(汉典史字的基本解释)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

国产永久免费高清在线观看视频 | 免费一级毛毛片 | 国产精品久久久久久久毛片 | 狠狠操天天干 | 日韩中文在线观看 | 亚洲精品成人 | 蜜臀精品久久久久久蜜臀 | 日韩a在线 | 欧美夫妻生活视频 | 丁香综合av| 女人18毛片90分钟 | 米奇四色影视 | 国产一区二区免费在线观看 | 青草视频在线 | 久久少妇免费视频 | 欧美极品久久 | 久久黄视频 | 国产成人一区二区在线观看 | www.久久免费 | 精品国产一区二区三区四区在线观看 | 久久艹久久 | 国产高清av | av线上免费看| 亚洲国产精品va在线看黑人动漫 | 91精品国自产在线 | 爱爱一区 | 精品久久国产精品 | 香蕉影视在线观看 | 这里只有精品视频在线 | 午夜狠狠干 | 不卡精品| 日韩动态视频 | 日p视频在线观看 | 国产精品亚洲片夜色在线 | 国产天天爽 | 精品国产一区二区三区免费 | 最近中文字幕免费av | 国产在线播放一区二区 | 91大片网站 | 亚洲国产精品一区二区尤物区 | 欧美中文字幕第一页 | 一级片免费观看视频 | www日日| 日韩av不卡播放 | 99精品免费久久久久久久久 | www.天天成人国产电影 | 国产高清免费视频 | 亚洲精品色视频 | 精品久久久久久久久久久久久久久久久久 | 91视频久久久久久 | 超级碰碰免费视频 | 日韩视频一区二区在线观看 | wwwwww黄| 激情综合网在线观看 | 日韩中文字幕视频在线 | 在线免费av观看 | 久久9精品 | 在线国产日本 | 黄色91在线 | 蜜桃视频精品 | 丁香综合五月 | 99国内精品| 久久av免费 | 日日爽视频 | 国产专区第一页 | 五月天久久激情 | 国产精品你懂的在线观看 | 日韩免费在线观看网站 | 成人h电影 | 欧美日韩观看 | 国产成人福利在线观看 | 欧美精品亚洲精品日韩精品 | 综合久久精品 | 欧美日韩p片 | 日韩电影在线观看一区二区三区 | 久久99九九99精品 | 中文字幕在线观看免费高清电影 | 久久成人一区二区 | 欧美韩日在线 | 密桃av在线| 天天射天天干天天插 | 精品亚洲免费 | 最近中文字幕高清字幕免费mv | 大胆欧美gogo免费视频一二区 | 成人永久视频 | 国产亚洲欧洲 | 国产粉嫩在线 | 亚洲aⅴ免费在线观看 | 99久久久久国产精品免费 | 青青草国产在线 | 玖玖国产精品视频 | 国产精品video | 国内亚洲精品 | 色夜影院 | 亚州日韩中文字幕 | 最新91在线视频 | 欧美日韩一级久久久久久免费看 | 免费裸体视频网 | 超碰.com| 国产精品手机看片 | 在线观看一二三区 | 91麻豆精品国产91久久久久久久久 | 婷婷六月天综合 | 日本中文字幕一二区观 | 成人av中文字幕 | 91精品综合在线观看 | 日韩欧美黄色网址 | 日韩电影在线观看一区 | 欧美性色xo影院 | 91精品久久久久久久99蜜桃 | 国产一性一爱一乱一交 | 亚a在线 | 天天躁日日躁狠狠躁av中文 | 国产特黄色片 | 日本夜夜草视频网站 | 色综合久久网 | 91在线porny国产在线看 | 黄色av免费 | 国产精品久久久久久久久软件 | 日韩欧美一区二区不卡 | 国产免费人成xvideos视频 | 五月天久久久 | 婷婷六月天天 | 日韩av资源在线观看 | 色婷婷88av视频一二三区 | 一级淫片在线观看 | 中文字幕资源网在线观看 | 免费三级大片 | 久久av免费 | av片在线看 | 日本老少交| 成人av午夜 | 亚洲va韩国va欧美va精四季 | 欧美日韩精品在线免费观看 | 91高清视频在线 | 国产亚洲精品女人久久久久久 | 国内精品久久久久久久97牛牛 | 久久人人射 | 在线亚洲人成电影网站色www | 很黄很污的视频网站 | 欧美色图亚洲图片 | 九九热精品视频在线观看 | 综合久久久久久久久 | 亚洲理论在线观看电影 | 久在线观看 | 人人射人人爽 | 久久精品国产久精国产 | 在线国产视频观看 | 欧美日韩视频观看 | 天天色婷婷| 久久福利小视频 | 美女网站在线播放 | 国产精品激情 | 久久五月精品 | 高清中文字幕av | 中文字幕在线播放日韩 | 国产成人a亚洲精品v | 国产精品久久久久久av | 色视频在线看 | 狠狠网站 | 久插视频 | 一区二区三区动漫 | 国产在线2020| 日韩美女免费线视频 | 色在线中文字幕 | 看片的网址 | 91高清免费在线观看 | 婷婷色在线资源 | 色国产精品| 日日夜夜骑 | 97人人添人澡人人爽超碰动图 | 黄色www| 久久久麻豆精品一区二区 | 久久精品激情 | 国产精品久久久久久久久久白浆 | 超碰在线97免费 | 人人射人人 | 国产人成看黄久久久久久久久 | 日日爱影视 | 最近中文字幕久久 | 婷婷av网站 | 亚洲在线精品 | 欧美国产日韩一区二区三区 | 欧美日韩69 | 天天操夜夜操国产精品 | 少妇视频一区 | 91人人澡人人爽 | 欧美一级电影在线观看 | 国产亚洲视频在线 | 久久精品99视频 | 99 久久久久| 欧美一级片免费在线观看 | 午夜18视频在线观看 | 国产精品伦一区二区三区视频 | 亚洲天堂网视频 | 久久久久一区二区三区四区 | 黄色精品久久 | 国产一级性生活 | 国产不卡在线看 | 国产精品美女久久久久久网站 | av韩国在线 | 国产精品高潮呻吟久久久久 | 青草草在线视频 | 午夜精品久久久久久久久久久 | 欧美日韩中字 | 亚洲视频 中文字幕 | 99超碰在线观看 | 久久99国产精品久久99 | 中文字幕制服丝袜av久久 | www.久久免费视频 | 天天搞天天 | 国产精品麻豆欧美日韩ww | 成年人视频免费在线播放 | 国产一二三区在线观看 | 国产 日韩 在线 亚洲 字幕 中文 | 免费黄色在线播放 | 米奇影视7777 | 51久久夜色精品国产麻豆 | h视频日本 | 亚洲人视频在线 | 手机av在线免费观看 | 精品理论片 | 日韩最新中文字幕 | 亚洲理论影院 | 免费观看丰满少妇做爰 | 中文字幕av有码 | 天天干天天操天天射 | 久久久精品国产一区二区电影四季 | 视频一区在线免费观看 | 黄网站色| 九色精品在线 | 九九精品视频在线观看 | 久久久久免费精品国产 | 91午夜精品| 中文字幕丝袜一区二区 | av高清在线| 久久成人国产精品免费软件 | 在线观看国产一区 | 国产美女免费观看 | 日韩一区二区三区免费视频 | 99久久99视频只有精品 | 欧美精品xxx| 国产精品99久久久久久有的能看 | 久久在草 | 成人小视频在线免费观看 | 6080yy精品一区二区三区 | 91视频国产免费 | 久久欧美在线电影 | 在线a视频 | 99精品黄色 | 色狠狠综合 | 久草国产视频 | 一区二区不卡 | 不卡视频一区二区三区 | 精品国产一区二区三区久久 | 亚洲一区二区天堂 | 天天干天天做 | 久久久久久久免费观看 | 久久免费观看视频 | 日日躁夜夜躁aaaaxxxx | 91视频在线观看大全 | 国产精品入口66mio女同 | 国产丝袜高跟 | 欧美日韩国产精品一区二区亚洲 | 2019天天干夜夜操 | 亚洲欧美一区二区三区孕妇写真 | 日韩美av在线| 99精品视频免费看 | 91成年人在线观看 | 久久这里只有精品23 | 欧美精品三级 | 国产精品成人一区二区三区吃奶 | 国语精品免费视频 | 99 精品 在线| 亚洲欧洲日韩在线观看 | 欧美精品xxx | 国产小视频在线观看 | 国产99久久久国产精品免费看 | 成人免费视频网 | 午夜电影av | 免费进去里的视频 | 国产区在线 | 992tv人人草 黄色国产区 | 99r精品视频在线观看 | 日韩欧美高清一区二区 | 色全色在线资源网 | 久久久99精品免费观看 | 国产精品成久久久久 | 国产伦理久久精品久久久久_ | 午夜av在线 | 亚洲久久视频 | 久久精品91视频 | 97视频在线观看播放 | 久久精品网站免费观看 | 国产亚洲精品久久久久久 | 欧美成人在线免费观看 | 精品福利av | 91久久电影| 国产中文字幕网 | 久久激情精品 | 免费在线观看视频一区 | 久草五月 | 欧美网站黄色 | 久草在线最新 | 免费中午字幕无吗 | 日韩高清www | 在线草| 中文在线中文资源 | 91成年人在线观看 | 99久久超碰中文字幕伊人 | 青草视频网 | 182午夜在线观看 | 精品亚洲视频在线观看 | 国产精品久久 | 中文免费观看 | 国产九九精品视频 | 亚洲精品小视频 | 天天色天 | 天天操天天色天天射 | 亚洲视频axxx| 91亚洲在线观看 | 中文在线免费一区三区 | 国产成人黄色网址 | 美女视频a美女大全免费下载蜜臀 | 成人啊 v| 韩国在线视频一区 | 久久www免费视频 | 成人午夜片av在线看 | 一区三区在线欧 | 国内丰满少妇猛烈精品播放 | 天天色综合三 | 天堂在线一区 | 精品久久久久免费极品大片 | 国产123av| 久色 网 | 亚洲国内精品视频 | 色干干 | 一区二区三区四区精品视频 | 午夜精品视频免费在线观看 | 国产偷在线 | 久久精品国产亚洲精品2020 | 国产精品初高中精品久久 | 久久久久一区二区三区 | 国产精品久久久久久久久久妇女 | 91桃色在线观看视频 | 最新中文字幕视频 | 日日日干| 亚洲视频在线观看免费 | 国产综合激情 | 超碰公开97 | 在线免费观看视频 | 一区二区伦理 | 一区二区欧美日韩 | 日日夜夜天天久久 | 精品国产一区二区三区久久 | 久草在线视频新 | 欧美成人91 | 女人高潮一级片 | 99精品欧美一区二区三区黑人哦 | 久久高清片 | 亚洲欧洲xxxx | 久久视频99| 欧美日韩啪啪 | 狠狠干夜夜 | 亚州精品国产 | 中文字幕免费成人 | 91视频传媒 | 激情小说网站亚洲综合网 | 精品美女视频 | 激情婷婷六月 | 有码视频在线观看 | 国产精品18久久久久久不卡孕妇 | 一区电影 | 中文字幕成人一区 | 亚洲精品网站 | 久久国产区 | 欧美日韩亚洲在线观看 | 久久久久久久久久久免费视频 | 国产精品久久久久久久久久久免费 | 国内精品在线看 | 丁香综合 | 亚洲韩国一区二区三区 | 在线观看深夜视频 | 亚洲综合涩 | 热re99久久精品国产66热 | 亚洲专区欧美专区 | 97夜夜澡人人双人人人喊 | 免费成人av在线看 | 毛片永久免费 | 黄色美女免费网站 | 久热免费在线观看 | 久久精国产| 国产成人精品一区二区三区福利 | 国产美女被啪进深处喷白浆视频 | 国产黄色片免费在线观看 | 四虎永久国产精品 | 夜夜视频欧洲 | 国产男男gay做爰 | 91亚洲激情 | 女女av在线 | 久久久影视 | 成人午夜免费福利 | 日韩中文字幕一区 | 日韩av一区二区三区四区 | 成人免费网站视频 | 久久久国产精品视频 | 欧美激情视频一区 | 久久人人97超碰com | 在线视频成人 | 日韩黄在线观看 | 色美女在线| 亚洲精品综合一二三区在线观看 | 区一区二在线 | 日本在线观看中文字幕无线观看 | 亚洲理论电影网 | 黄色片免费电影 | 在线免费观看国产黄色 | 伊人网综合在线观看 | 一区二区影视 | 在线看岛国av | 中文字幕黄色网 | 国产美女免费观看 | 亚洲午夜在线视频 | 999视频网站 | 国产九九九视频 | 亚洲精品视频在线 | 99精品视频在线看 | 国产污视频在线观看 | 日韩极品在线 | 免费看成人a | 国产精品一区二区久久久久 | 黄色字幕网 | 黄色小网站在线 | 亚州成人av在线 | 日韩99热| 99精品在线免费观看 | 丁香激情综合久久伊人久久 | 久久人人爽人人爽人人片av免费 | 国产精品免费在线播放 | 91亚洲在线观看 | 精品久久久久久综合日本 | 综合久久久久久久久 | 国产成人精品一区二区三区福利 | 日本精品小视频 | 黄色一级动作片 | www.黄色小说.com | 五月宗合网 | 中文字幕欧美激情 | 中文av影院 | a在线视频v视频 | 亚洲va欧美va | 在线观看免费视频 | 国内久久久久 | 中文永久免费观看 | 精品免费国产一区二区三区四区 | 99视频精品 | 国产三级久久久 | 99c视频在线 | 日韩美女黄色片 | 欧美成人亚洲成人 | 波多野结衣最新 | 久久精品牌麻豆国产大山 | 久久久久久麻豆 | 高清中文字幕av | 亚洲日本国产精品 | 国产99一区二区 | 精品亚洲免费 | 国产精品免费看久久久8精臀av | 亚洲女同videos | 美女网站色免费 | 久久se视频 | 欧亚日韩精品一区二区在线 | www.com黄| 国产在线观看二区 | 国产自产在线视频 | 天天爽天天碰狠狠添 | 欧美一进一出抽搐大尺度视频 | 黄色av一区| 人人爱爱| 久久九九久久精品 | 综合久久久久 | 激情一区二区三区欧美 | 久久久久久久国产精品视频 | 99久久婷婷国产一区二区三区 | 99精品国产99久久久久久福利 | 国产精品久久二区 | 插插插色综合 | 日韩成人在线免费观看 | 五月婷婷六月丁香在线观看 | 国产69精品久久久久99尤 | 人人爽人人舔 | 国产精品久久久久久久久久久久久 | 97超碰在线资源 | 国产精品18久久久久久久 | 五月天电影免费在线观看一区 | 中日韩在线视频 | 成人污视频在线观看 | 成人午夜网 | 亚洲 欧美 成人 | 中文字幕中文字幕 | 91精品欧美 | 免费观看视频黄 | 91人人人 | 日本不卡久久 | 狠狠躁夜夜躁人人爽视频 | 九色精品免费永久在线 | 69久久99精品久久久久婷婷 | 成人免费色 | 不卡国产视频 | av理论电影 | 国产丝袜美腿在线 | 久久精选| 久久久久久黄 | 精品一区二区在线观看 | 日韩精品一区二区三区免费观看 | 精品视频成人 | 久久美女精品 | www99久久 | 中文字幕中文字幕在线中文字幕三区 | 四虎影视av | 国产视频1| 久久99精品久久只有精品 | 国产91亚洲精品 | 69av视频在线观看 | 天天躁日日躁狠狠躁 | 亚洲综合色丁香婷婷六月图片 | 视频一区二区在线 | 久久国产精品免费观看 | 成人黄色电影在线播放 | 久久99热精品这里久久精品 | 99精品欧美一区二区三区 | 国产成人61精品免费看片 | 你操综合 | 国产精品成人自产拍在线观看 | 欧美日韩不卡一区二区三区 | 黄色aaa毛片 | 天堂网中文在线 | 久色 网 | 亚洲黄色一级电影 | 免费福利片2019潦草影视午夜 | 婷婷五情天综123 | 99久e精品热线免费 99国产精品久久久久久久久久 | 国产精品黑丝在线观看 | 日韩美女免费线视频 | 色婷婷色 | 午夜视频不卡 | 天天色综合天天 | 玖玖在线观看视频 | 国产一区av在线 | 日韩国产精品久久久久久亚洲 | 91麻豆精品国产 | 国产成人精品网站 | 最近最新最好看中文视频 | 高清在线观看av | 97色婷婷人人爽人人 | 国产精品成人自拍 | 国产91对白在线播 | 黄网站色视频免费观看 | 深夜精品福利 | 欧美三级高清 | 天天爱av导航 | 久久99国产精品自在自在app | 精品美女久久 | a在线v| 日本高清免费中文字幕 | 一级α片免费看 | 国产精品永久免费 | 婷婷色六月天 | 网站在线观看日韩 | 九精品| 精品国产理论片 | 久久久久久久久毛片精品 | 精品国产1区二区 | 一区二区三区四区久久 | 成人国产精品免费 | 婷婷中文字幕综合 | 麻豆视频免费入口 | 国产精品久久久久aaaa九色 | 色吊丝av中文字幕 | 99国产在线观看 | 久久99国产精品视频 | 黄污视频网站 | 日韩一区二区三区视频在线 | 欧美福利精品 | 在线国产91 | 日韩精品久久久久久久电影99爱 | 丰满少妇在线观看网站 | 日韩av手机在线看 | 精品国产日本 | 深夜免费福利视频 | a成人v在线 | 中文字幕九九 | 在线观看免费日韩 | 2000xxx影视 | 欧美激情综合五月色丁香 | 久久九九免费视频 | 婷婷精品在线视频 | 99精品在线免费观看 | 天天干天天操天天搞 | 久久丁香网 | 国产小视频在线观看 | 国产一线二线三线性视频 | 在线观看成人福利 | 日操操 | 久久草在线视频国产 | 免费在线国产精品 | 免费观看的av网站 | 在线观看国产日韩欧美 | 九九天堂| 丁香视频在线观看 | 日韩在线观看视频一区二区三区 | 日韩在线视 | 久久无码av一区二区三区电影网 | 国产+日韩欧美 | 婷婷免费视频 | 日韩久久精品一区 | 96超碰在线 | 亚洲电影影音先锋 | 国产精品夜夜夜一区二区三区尤 | 精品国内自产拍在线观看视频 | 中文字幕久久精品 | 日本在线精品视频 | 免费看片成人 | 日韩亚洲国产中文字幕 | 亚洲成人午夜在线 | 91精品久久香蕉国产线看观看 | 国产五十路毛片 | 91成人精品一区在线播放69 | 免费成人短视频 | 在线观看av国产 | av成人免费观看 | 99草视频在线观看 | 成人福利在线观看 | 99热精品国产一区二区在线观看 | 精品国产理论 | 中文字幕在线观看亚洲 | 五月婷在线 | 成人全视频免费观看在线看 | 免费看片在线观看 | 午夜天使 | 亚洲干| 91成人网页版 | 久草视频中文在线 | 日本中文字幕电影在线免费观看 | 视频在线在亚洲 | 在线视频一二三 | 久久视频网址 | 中文在线a天堂 | 国产精品夜夜夜一区二区三区尤 | 亚洲最大av网站 | 亚洲乱码国产乱码精品天美传媒 | 娇妻呻吟一区二区三区 | 国产又粗又硬又爽的视频 | 国产小视频免费观看 | 亚洲国产中文在线观看 | 亚洲 精品在线视频 | 色欲综合视频天天天 | 欧美日韩中文字幕视频 | 日韩一三区| 超碰激情在线 | 天堂在线视频中文网 | 天天激情天天干 | av爱干| 精品国产一区二区三区久久 | 日韩在线观看视频在线 | 国产高清免费观看 | 久久激情五月激情 | 91免费高清 | 久久国产精品久久久久 | 日本韩国欧美在线观看 | 天天综合导航 | 麻豆精品视频在线 | 国产综合小视频 | 狠狠狠狠狠狠天天爱 | 亚洲欧洲日韩在线观看 | 久久久久久久网站 | 久久久亚洲电影 | 99精品视频免费观看视频 | 国产特级毛片aaaaaa毛片 | 国产激情小视频在线观看 | 玖玖玖影院 | 一本一本久久aa综合精品 | 久久久资源网 | 蜜桃视频在线视频 | 午夜精品一区二区三区免费视频 | 成人免费xyz网站 | 欧美日韩久久一区 | 日韩高清免费观看 | 99产精品成人啪免费网站 | 久久综合一本 | 在线看成人av | 国产 欧美 日产久久 | 在线电影av | 麻豆视频在线看 | 91精品国产91热久久久做人人 | 中文字幕在线观看网址 | 久久99久久99精品免观看粉嫩 | 麻豆免费精品视频 | 99久国产 | 激情视频免费观看 | 在线观看精品一区 | 国产精品18久久久久久久网站 | 天天干天天上 | 亚洲 中文字幕av | 丁香花在线观看免费完整版视频 | 91精品中文字幕 | 欧美日本不卡视频 | 欧美性色黄大片在线观看 | 黄色精品久久 | 久久99精品视频 | 欧美性生交大片免网 | 91精品一区二区三区蜜桃 | 亚洲伊人第一页 | 91.dizhi永久地址最新 | 免费手机黄色网址 | 日韩精品一区二区三区水蜜桃 | 欧美片一区二区三区 | 天天干,天天插 | 在线免费观看国产 | 综合网欧美 | 成人在线观看免费 | 国产一区视频导航 | 久久99精品波多结衣一区 | 欧美国产不卡 | 国产精品久久久精品 | 二区三区在线观看 | 黄色.com| 久草在线播放视频 | 国内精品久久久久久久影视简单 | 中文字幕资源网 国产 | 日韩高清一| av不卡免费看| 美女免费视频观看网站 | 国产成人精品电影久久久 | 四虎在线视频免费观看 | 综合色婷婷 | 精品久久久免费 | 亚洲精品免费在线播放 | 日韩啪视频 | 久草在线电影网 | 国产91大片 | 久草香蕉在线视频 | 欧美福利网址 | 在线 国产 亚洲 欧美 | 国产免费人人看 | 草草草影院 | 精品一区欧美 | 久久观看| 国产精品18毛片一区二区 | 亚洲一区视频免费观看 | 色之综合网 | 中文字幕人成一区 | 在线播放 日韩专区 | 婷婷.com| 9在线观看免费 | 射久久久| 国产高清在线永久 | 久久综合狠狠综合 | 久久精品播放 | 9992tv成人免费看片 | 99久久99热这里只有精品 | 免费在线一区二区 | 天天综合色天天综合 | 国产精品麻豆三级一区视频 | 日韩欧美精品在线 | 91精品电影 | 国产高清视频在线免费观看 | 在线观看视频国产 | 日韩精品一区在线观看 | 日本中文不卡 | 五月开心六月伊人色婷婷 | 日韩激情在线 | 久久国产精品成人免费浪潮 | 黄色大片国产 | 在线成人一区 | 精品亚洲成人 | www.久艹| 亚洲黄色av网址 | 国产精品成人品 | 中文字幕观看av | 91桃花视频 | 久久免费视频2 | 国产视频美女 | 亚洲精品国产视频 | 日韩专区 在线 | 射射射综合网 | 欧美老女人xx | 久久久久五月天 | 91色一区二区三区 | 深爱激情开心 | 黄色小网站在线观看 | 国产美女视频一区 | 欧美91精品国产自产 | 深夜免费福利视频 | 91在线视频观看免费 | 国产乱视频 | 久久婷婷精品视频 | 一区二区中文字幕在线播放 | 久久y| 国产成人在线观看 | 国产综合在线观看视频 | 99久久网站| 久久精品久久精品久久精品 | 国产精品99久久久久久人免费 | 中国一级特黄毛片大片久久 | 亚洲精品一区中文字幕乱码 | 欧美做受高潮1 | 色综合亚洲精品激情狠狠 | 国产免费又粗又猛又爽 | 久99久中文字幕在线 | 免费久久视频 | 99精品免费网 | 在线观看岛国片 | 国产精品久久久久久久久久久不卡 | 九草在线观看 | 在线视频99 | 69亚洲乱 | 日本少妇高清做爰视频 | 久久精品国产成人精品 | 天天干婷婷 | www久久久 | 91网站在线视频 | 日韩大陆欧美高清视频区 | 日韩欧美国产精品 | 超碰在线人人草 | 国产区精品在线观看 | 又黄又爽又湿又无遮挡的在线视频 | 一级片免费观看视频 | 欧美一二三视频 | 天堂网中文在线 | 成人三级视频 | 免费在线观看a v | 久久观看最新视频 | 亚洲精品在线视频观看 | 国产 日韩 在线 亚洲 字幕 中文 | 一区三区在线欧 | 亚洲黄色免费电影 | 中文字幕91在线 | 最近免费中文字幕大全高清10 | 日韩免费一级a毛片在线播放一级 | 片网站| 久久夜色精品国产欧美乱极品 | 国产在线va | 国产精品久久久久毛片大屁完整版 | 激情欧美丁香 | 91在线成人 | 国产成人精品国内自产拍免费看 | 又黄又刺激视频 | 丁香婷婷激情国产高清秒播 | 91最新中文字幕 | av亚洲产国偷v产偷v自拍小说 | 超碰97免费观看 | 99精品亚洲 | 蜜臀久久99精品久久久酒店新书 | 黄色免费电影网站 | 欧美一区二区在线免费看 | 一色屋精品视频在线观看 | 久草视频在线播放 | 久久免费99精品久久久久久 | 日本资源中文字幕在线 | 中文字幕在线久一本久 | 久久一区91 | 久久国产精品电影 | 96av在线视频 | 黄色免费网战 | 92中文资源在线 | 久久久久久久久久久久影院 | 久久成人人人人精品欧 | 中文字幕在线观看完整版 | 婷婷av电影 | 欧美尹人| 91在线免费视频 | 天天插天天色 | 欧美视频日韩 | 日本一区二区不卡高清 | 91在线永久| 久久精选 | 国产免费一区二区三区最新6 | 国产天天爽| 国产视频中文字幕在线观看 | 国产亚洲一区二区在线观看 | 黄色片免费在线 | av中文字幕不卡 | 国产乱码精品一区二区三区介绍 | 国产女教师精品久久av | 美女久久一区 | 999久久久久久久久6666 | 亚洲天天在线 | 久精品一区 | 91久久精品一区 | 人人草人人草 | 日韩免费久久 | 中文字幕在线观看av | 夜夜婷婷 | 91爱爱电影 | 天天操综合| 亚洲一区日韩精品 | 国产一级一片免费播放放 | 国产原创91| 在线网址你懂得 | 亚洲精品自拍视频在线观看 | 亚洲日本中文字幕在线观看 | 精品国产aⅴ麻豆 | 97在线观看视频免费 | 91在线小视频 | 爱情影院aqdy鲁丝片二区 | 日韩高清无线码2023 | 国产破处在线视频 | 国产精品国产三级国产专区53 | 美女视频黄,久久 | 国产精品孕妇 | 午夜成人免费电影 | 日本黄色一级电影 | 91最新中文字幕 | 欧美在线free | 天天添夜夜操 | 婷婷伊人五月天 | 99精品乱码国产在线观看 | av韩国在线| a在线观看视频 | 国产中文字幕网 | 97精品在线视频 | 亚洲国产精品成人va在线观看 | 91欧美视频网站 | 色多多污污 | 亚洲综合色视频在线观看 | 奇米先锋 | 久久久久久亚洲精品 | 亚洲精品乱码久久久久久蜜桃欧美 | 午夜精品一区二区三区在线 | 亚洲黄色在线免费观看 | 五月婷婷色综合 | 欧美激情在线网站 | 91干干干 | 久久伊99综合婷婷久久伊 | 手机看片国产 | aaa日本高清在线播放免费观看 | 国产精品99久久免费观看 | 91视频在线国产 | 国产不卡av在线播放 | 丝袜美女在线观看 | 最新国产精品视频 | 国产女人18毛片水真多18精品 | 国产精品网址在线观看 | 在线免费观看羞羞视频 | 免费a现在观看 | 探花视频在线观看免费版 | 蜜臀av网站| 久久精品国产一区二区三区 | 国产精品免费一区二区三区在线观看 | 婷婷丁香激情综合 | 一区二区三区视频网站 | 婷婷在线五月 | 久久久国产高清 | 精品一区二区在线播放 | 丁香影院在线 | 久久色视频 | 午夜av电影| 色婷婷狠狠| 欧美一区二区三区在线视频观看 | 国产91在线 | 美洲 | 国产亚洲精品久久久久动 | 国产精品免费视频一区二区 | 免费看国产视频 | 欧美国产日韩久久 | 国产免费视频一区二区裸体 | 国产18精品乱码免费看 | 日韩一级电影在线观看 | 中文字幕精品在线 | 久久影院亚洲 | 在线观看欧美成人 | 国产96在线视频 | 国产在线观看av | 在线观看中文字幕视频 | 日韩欧美在线视频一区二区 | 啪一啪在线 | 国产一区二区在线免费播放 | 国产99久久久精品 | 99久久综合精品五月天 | 精品国内自产拍在线观看视频 | 免费在线观看亚洲视频 | 国产精品久久久久高潮 | 久久理论片 | 久草 | 96超碰在线| 精品久久久免费视频 | 蜜臀aⅴ精品一区二区三区 久久视屏网 | 亚洲高清视频在线观看免费 | 国产日韩欧美在线一区 | 91精品推荐 | 日日操天天射 | 麻豆免费观看视频 | 亚洲全部视频 | www.夜夜 | 免费视频你懂的 | 亚洲在线免费视频 | 超碰在线人 | 99国产情侣在线播放 |