【大模型:知識圖譜】--5.neo4j數據庫管理(cypher語法2)

目錄

1.節點語法

1.1.CREATE--創建節點

1.2.MATCH--查詢節點

1.3.RETURN--返回節點

1.4.WHERE--過濾節點

2.關系語法

2.1.創建關系

2.2.查詢關系

3.刪除語法

3.1.DELETE 刪除

3.2.REMOVE 刪除

4.功能補充

4.1.SET (添加屬性)

4.2.NULL 值

4.3.ORDER BY (排序)

4.4.LIMIT 和 SKIP (限制)


1.節點語法

Cypher?采用一對圓括號來表示節點。如:(), (foo)。下面是一些常見的節點表示法:

// 表示一個節點,但是沒有屬性
()
// 節點變量為 matrix
(matrix)
// 節點標簽為 Movie 的節點
(:Movie)
// 節點變量為 matrix,節點標簽為 Movie 的節點
(matrix:Movie)
// 節點變量為 matrix,節點標簽為 Movie,節點屬性 title 為 ET·Go 的節點
(matrix:Movie {title: "ET·Go"})
// 節點變量為 matrix,節點標簽為 Movie,節點屬性 title 為 Spider Man ,released 為 1997 的節點
(matrix:Movie {title: "Spider Man", released: 1997})

1.1.CREATE--創建節點

create?語句是創建模型語句用來創建數據模型。

// 創建簡單節點
create (n)
// 創建多個節點
create (n),(m)
// 創建帶標簽和屬性的節點并返回節點
create (n:person {name:"如來"}) return n

1.2.MATCH--查詢節點

Neo4j CQL MATCH 命令用于

  • 從數據庫獲取有關節點和屬性的數據;
  • 從數據庫獲取有關節點,關系和屬性的數據。

match (Person:person {name: "如來"}) return Person

Person:變量(任意)

person:標簽

{}:屬性

():節點

1.3.RETURN--返回節點

Neo4j CQL RETURN 子句用于

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

注意:RETURNMATCH?兩個需要搭配使用。

1.4.WHERE--過濾節點

像 SQL 一樣,Neo4j CQL 在 CQL MATCH 命令中提供了 WHERE 子句來過濾 MATCH 查詢的結果。

MATCH (n:person) where n.name='孫悟空' or n.name='豬八戒' RETURN n 

2.關系語法

Cypher 使用一對短橫線(即“–”)表示:一個無方向關系。有方向的關系在其中一端加上一個箭頭(即“<–”或“–>”)。方括號表達式?[…]?可用于添加關系信息。里面可以包含變量、屬性和或者類型信息。關系的常見表達方式如下:

// 無方向關系
--
// 有方向關系,指向一個節點
-->
// 有方向的關系,關系變量為 reole
-[role]->
// 有方向的關系,關系標簽為 ACTED_IN
-[:ACTED_IN]->
// 有方向的關系,關系標簽為 ACTED_IN,關系變量為 role
-[role:ACTED_IN]->
// 有方向的關系,關系標簽為 ACTED_IN,關系變量為 role,屬性 roles 的值為 Neo
-[role:ACTED_IN {roles: ["Neo"]}]->

2.1.創建關系

Neo4j 圖數據庫遵循屬性圖模型來存儲和管理其數據。 根據屬性圖模型,關系應該是定向的。 否則,Neo4j 將拋出一個錯誤消息。 基于方向性,Neo4j 關系被分為兩種主要類型。

  • 單向關系
  • 雙向關系

使用新節點創建關系

CREATE (n:person {name:'楊戩'})-[r:師傅]->(m:person {name:'玉鼎真人'}) return type(r)

create (n:person {name:'沙僧'}),(m:person{name:'唐僧'}) create (n)-[r:`師傅`{relation:'師傅'}]->(m) return r

2.2.查詢關系

MATCH (a)-[r:師傅]->(b)
RETURN a, r, b

3.刪除語法

3.1.DELETE 刪除

  • 刪除節點;

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

# 刪除節點(前提:節點不存在關系)
MATCH (n:person {name:"白龍馬"}) delete n;
# 刪除關系
MATCH (n:person {name:"沙僧"})<-[r]-(m) delete r return type(r);

注意:刪除結點的前提是節點沒有關系。

3.2.REMOVE 刪除

有時基于客戶端要求,我們需要向現有節點或關系添加或刪除屬性。我們使用Neo4j CQL REMOVE 子句來刪除節點或關系的現有屬性。

  • 刪除節點或關系的標簽;

  • 刪除節點或關系的屬性。

  // 刪除屬性MATCH (n:role {name:"fox"}) remove n.age return n;// 創建節點(兩個標簽)CREATE (m:role:person {name:"cat233"})// 刪除標簽MATCH (m:role:person {name:"cat233"}) remove m:person return m

4.功能補充

4.1.SET (添加屬性)

有時,根據我們的客戶端要求,我們需要向現有節點或關系添加新屬性。要做到這一點,Neo4j CQL 提供了一個SET子句。

向現有節點或關系添加新屬性;
添加或更新屬性值。 MATCH (n:role {name:"cat"}) set n.age=32 return n

4.2.NULL 值

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

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

// 查詢是否為空
match (n:`西游`) where n.label is null return id(n),n.name,n.tail,n.label

4.3.ORDER BY (排序)

Neo4j CQL 在 MATCH 命令中提供了?ORDER BY?子句,對 MATCH 查詢返回的結果進行排序。 我們可以按升序或降序對行進行排序。默認情況下,它按升序對行進行排序。 如果我們要按降序對它們進行排序,我們需要使用?DESC?子句。

// 按 id 進行降序
MATCH (n:`西游`) RETURN id(n),n.name order by id(n) desc

4.4.LIMIT 和 SKIP (限制)

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

// 前兩行 
MATCH (n:`西游`) RETURN n LIMIT 2 
// 忽略前兩行 
MATCH (n:person) RETURN n SKIP 2

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/83684.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/83684.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/83684.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

結構體指針與非指針 問題及解決

問題描述 第一段位于LCD.h和LCD.c中&#xff0c; 定義個一個結構體lcd_params&#xff0c;并直接給與指針名*p_lcd_params; 我發現我在調用這個結構體時&#xff0c;即在LCD.c中&#xff0c;使用指針類型定義的 static p_lcd_params p_array_lcd[LCD_NUM]; static p_lcd_par…

【設計模式-3.7】結構型——組合模式

說明&#xff1a;本文介紹結構型設計模式之一的組合模式 定義 組合模式&#xff08;Composite Pattern&#xff09;又叫作整體-部分&#xff08;Part-Whole&#xff09;模式&#xff0c;它的宗旨是通過將單個對象&#xff08;葉子節點&#xff09;和組合對象&#xff08;樹枝…

【TMS570LC4357】之相關驅動開發學習記錄2

系列文章目錄 【TMS570LC4357】之工程創建 【TMS570LC4357】之工程配置修改 【TMS570LC4357】之HALCOGEN使用 【TMS570LC4357】之相關問題及解決 【TMS570LC4357】之相關驅動開發學習記錄1 ——————————————————— 前言 記錄筆者在第一次使用TMS570過程中對…

3D Gaussian splatting 05: 代碼閱讀-訓練整體流程

目錄 3D Gaussian splatting 01: 環境搭建3D Gaussian splatting 02: 快速評估3D Gaussian splatting 03: 用戶數據訓練和結果查看3D Gaussian splatting 04: 代碼閱讀-提取相機位姿和稀疏點云3D Gaussian splatting 05: 代碼閱讀-訓練整體流程3D Gaussian splatting 06: 代碼…

【黑馬程序員uniapp】項目配置、請求函數封裝

黑馬程序員前端項目uniapp小兔鮮兒微信小程序項目視頻教程&#xff0c;基于Vue3TsPiniauni-app的最新組合技術棧開發的電商業務全流程_嗶哩嗶哩_bilibili 參考 有代碼&#xff0c;還有app、h5頁面、小程序的演示 小兔鮮兒-vue3ts-uniapp-一套代碼多端部署: 小兔鮮兒-vue3ts-un…

前端使用 preview 插件預覽docx文件

目錄 前言一 引入插件二 JS 處理 前言 前端使用 preview 插件預覽docx文件 一 引入插件 建議下載至本地&#xff0c;靜態引入&#xff0c;核心的文件已打包&#xff08;前端使用 preview 插件預覽docx文件&#xff09;&#xff0c;在文章目錄處下載至本地&#xff0c;復制在項…

如何在運動中保護好半月板?

文章目錄 引言I 半月板的作用穩定作用緩沖作用潤滑作用II 在跳繩運動中保護好半月板III 半月板損傷自測IV 半月板“殺手”半月板損傷必須滿足四個因素:消耗品引言 膝蓋是連接大腿骨和小腿骨的地方,在兩部分骨頭的連接處,墊著兩片半月形的纖維軟骨板,這就是半月板。半月板分…

安科瑞防逆流方案落地內蒙古中高綠能光伏項目,筑牢北疆綠電安全防線

一、項目概況 內蒙古阿拉善中高綠能能源分布式光伏項目&#xff0c;位于內蒙古烏斯太鎮&#xff0c;裝機容量為7MW&#xff0c;采用自發自用、余電不上網模式。 用戶配電站為35kV用戶站&#xff0c;采用兩路電源單母線分段系統。本項目共設置12臺35/0.4kV變壓器&#xff0c;在…

1.3 fs模塊詳解

fs 模塊詳解 Node.js 的 fs 模塊提供了與文件系統交互的能力&#xff0c;是服務器端編程的核心模塊之一。它支持同步、異步&#xff08;回調式&#xff09;和 Promise 三種 API 風格&#xff0c;可滿足不同場景的需求。 1. 模塊引入 const fs require(fs); // 回調…

LeetCode 70 爬樓梯(Java)

爬樓梯問題&#xff1a;動態規劃與斐波那契的巧妙結合 問題描述 假設你正在爬樓梯&#xff0c;需要爬 n 階才能到達樓頂。每次你可以爬 1 或 2 個臺階。求有多少種不同的方法可以爬到樓頂&#xff1f; 示例&#xff1a; n 2 → 輸出 2&#xff08;1階1階 或 2階&#xff0…

【學習分享】shell基礎-參數傳遞

參數傳遞 我們可以在執行 Shell 腳本時&#xff0c;向腳本傳遞參數&#xff0c;腳本內獲取參數的格式為 $n&#xff0c;n 代表一個數字&#xff0c;1 為執行腳本的第一個參數&#xff0c;2 為執行腳本的第二個參數。 例如可以使用 $1、$2 等來引用傳遞給腳本的參數&#xff0…

Fluence推出“Pointless計劃”:五種方式參與RWA算力資產新時代

2025年6月1日&#xff0c;去中心化算力平臺 Fluence 正式宣布啟動“Pointless 計劃”——這是其《Fluence Vision 2026》戰略中四項核心舉措之一&#xff0c;旨在通過貢獻驅動的積分體系&#xff0c;激勵更廣泛的社區參與&#xff0c;為用戶帶來現實世界資產&#xff08;RWA&am…

Excel數據分析:基礎

在現代辦公環境中&#xff0c;Excel 是一款不可或缺的工具&#xff0c;它是 Microsoft&#xff08;微軟&#xff09;開發的電子表格軟件&#xff0c;用于處理和分析結構化數據。市場上還有其他類似的軟件&#xff0c;如 Google Sheets 和 Apple Numbers&#xff0c;但 Excel 以…

12V降5V12A大功率WD5030A,充電器、便攜式設備、網絡及工業領域的理想選擇

WD5030A 高效單片同步降壓型直流 / 直流轉換器 一、芯片核心概述 WD5030A 是一款高性能同步降壓型 DC/DC 轉換器&#xff0c;采用 平均電流模式控制架構&#xff08;帶頻率抖動功能&#xff09;&#xff0c;具備以下核心優勢&#xff1a; 精準電流控制&#xff1a;快速響應負…

企業級AI邁入黃金時代,企業該如何向AI“蝶變”?

科技云報到原創。 近日&#xff0c;微軟&#xff08;MSFT.US&#xff09;在最新全員大會上高調展示企業級AI業務進展&#xff0c;其中與巴克萊銀行達成的10萬份Copilot許可證交易成為焦點。 微軟首席商務官賈德森阿爾索夫在會上披露&#xff0c;這家英國金融巨頭已簽約采購相…

Java編程課(一)

Java編程課 一、java簡介二、Java基礎語法2.1 環境搭建2.2 使用Intellij IDEA新建java項目2.3 Java運行介紹2.4 參數說明2.5 Java基礎語法2.6 注釋2.7 變量和常量一、java簡介 Java是一種廣泛使用的高級編程語言,最初由Sun Microsystems于1995年發布。它被設計為具有簡單、可…

【Java Web】速通Tomcat

參考筆記:JavaWeb 速通Tomcat_tomcat部署java項目-CSDN博客 目錄 一、Tomcat服務 1. 下載和安裝 2. 啟動Tomcat服務 3. 啟動Tomcat服務的注意事項 4. 關閉Tomcat服務 二、Tomcat的目錄結構 1. bin ?? 2. conf ?? 3. lib 4. logs 5. temp 6. webapps 7. work 三、Web項目…

Mysql 身份認證繞過漏洞 CVE-2012-2122

前言&#xff1a;CVE-2012-2122 是一個影響 MySQL 和 MariaDB 的身份驗證漏洞&#xff0c;存在于特定版本中 vulhub/mysql/CVE-2012-2122/README.zh-cn.md at master vulhub/vulhubhttps://github.com/vulhub/vulhub/blob/master/mysql/CVE-2012-2122/README.zh-cn.md 任務一…

Win10停更,Win11不好用?現在Mac電腦比Win11電腦更便宜

最近不少朋友在換電腦前都犯了難。 以前大家最常說的一句是&#xff1a;“Mac太貴了&#xff0c;還是買Windows吧。”但現在不一樣了&#xff0c;國補教育優惠下來&#xff0c;新款M4芯片的Mac mini的入門價已經降到了3000元左右&#xff0c;曾經的價格壁壘&#xff0c;已經不…

C#中Struct與IntPtr轉換:實用擴展方法

C#中Struct與IntPtr轉換&#xff1a;實用擴展方法 在 C# 編程的世界里&#xff0c;我們常常會遇到需要與非托管代碼交互&#xff0c;或者進行一些底層內存操作的場景。這時&#xff0c;IntPtr類型就顯得尤為重要&#xff0c;它可以表示一個指針或句柄&#xff0c;用來指向非托…