图数据库Neo4j学习二——cypher基本语法

news2024/11/25 19:45:30

1命名规范

  1. 名称应以字母字符开头,不以数字开头,名称不应包含符号,下划线除外
  2. 可以很长,最多65535( 2^16 - 1) 或65534字符,具体取决于 Neo4j 的版本
  3. 名称区分大小写。:PERSON和:Person是:person三个不同的标签,并且n和N是两个不同的变量。
  4. 前导和尾随空白字符将被自动删除。例如,
MATCH (  a  ) RETURN a
相当于
MATCH (a) RETURN a
  1. 以下是推荐的命名约定:
类型规范案例
节点标签驼峰式,以大写字符开头正例 :VehicleOwner 反例 :vehicle_owner
关系类型大写,使用下划线分隔单词正例 :OWNS_VEHICLE 反例 ::ownsVehicle

2 数据库操作

在关系型数据库mysql中,我们可以通过show databases来查看我们有哪些数据库,如下图所示
在这里插入图片描述
在图数据库neo4j中,我们想要查看有哪些数据库,他的查看语句于也是show databases,这点在语法规则上和mysql一样的。

2.1查询数据库

show databases

在这里插入图片描述
neo4j:系统默认的图数据库
system:系统库

2.2切换数据库

语法规则::use 数据库名

//切换到系统库
:use system

//切换到neo4j库
:use neo4j

下图表示,当前在system这个数据库下,我们现在要切换到neo4j这个数据库下
在这里插入图片描述

2.3创建数据库

//企业版才支持命令创建数据库
create database neo4j_hutao

社区版使用命令创建将会报如下错误
在这里插入图片描述

3节点操作

3.1创建节点

语法规则:CREATE (节点名称)

//(1)创建一个节点n
CREATE (n)

//(2)创建两个节点n和m
CREATE (n), (m)

//(3)创建一个节点n,并且为这个节点设置标签为User
CREATE (n:User)

//(4)创建一个节点n,设置标签,并且为这个节点添加属性
CREATE (n:User{userName:'胡涛', userAge:25, userSex:'男'}),

//(5)创建多个节点n,设置标签,并且为这个节点添加属性
CREATE (n1:User{userName:'胡涛1', userAge:25, userSex:'男'}),
    (n2:User{userName:'胡涛2', userAge:26, userSex:'男'})

如下,是我们使用上述的第五个命令创建的两个节点,胡涛1和胡涛2

在这里插入图片描述

3.2查询节点

当我们创建了节点以后,怎么查看我们的节点嗯?
语法规则:MATCH (节点)RETURN 节点

//(1)查找所有的节点
MATCH(n) RETURN n

在这里插入图片描述

//(2)查找指定标签(User)的节点,同理这里我们可以把User换成其他节点的标签
MATCH(n:User) RETURN n

在这里插入图片描述

//(3)查找某个指定属性的节点,即根据节点的属性进行查询
MATCH(n:User) WHERE n.userName = '胡涛1' RETURN n
或者
MATCH(n:User{userName:'胡涛1'}) RETURN n

这两种方式有什么区别嗯?
MATCH ( 节点 ) WHERE 节点属性
在这里插入图片描述
查询使用 WHERE n.userName = '胡涛1’子句来指定过滤条件,该条件要求节点的“userName”属性等于“胡涛1”。这个查询将遍历所有的“User”节点,并将符合条件的节点返回。这个查询可以使用索引来提高查询性能。
MATCH ( 节点 { 节点属性 } )
在这里插入图片描述
这个查询使用了节点属性的内联语法,“{userName:‘胡涛1’}”,来明确指定要匹配的属性和属性值。这个查询将直接在索引中查找名称为“胡涛1”的用户节点,并将其返回。这个查询通常比第一个查询更快,因为它直接利用了索引。
查询小技巧
如果要查询节点的某个属性等于特定值,最好使用内联语法来指定属性和属性值,这将利用索引并且可以更快地返回结果。
如果您需要更复杂的过滤条件,例如使用大于、小于、不等于等运算符,或者需要使用多个属性来过滤节点,则可以使用“WHERE”子句来构建查询。

//(4)返回节点的属性
MATCH(n:User) WHERE n.userName = '胡涛1' RETURN n.userName,n.userAge

当我查询节点的属性时,此时返回给我们的就不在是图,而是一个列表信息了
在这里插入图片描述

某些查询,我们可能无法使用节点属性的内敛语法,因此可能需要我们构造一些复杂的where子语句,或者使用特定的方法,此处不在展开,只介绍一些入门的示例。

//(5) 通匹符 * 查询 User节点中,userName带某个关键字的,例如名字中包含《涛》
match (n:User) where n.userName =~'.*涛.*' return n

//(6) starts with查询某个关键字开头的,例如名字中是《胡》开头的,同理还有其他方法 ends with /contains
match (n:User) where n.userName starts with '胡' return n

在这里插入图片描述
在这里插入图片描述

3.3删除节点

如果你上面已经学会了,查询节点,那么其实删除节点你也学会了
删除语法和查看语法一样,区别:查看是RETURN,删除是DELETE

将我们上面的查询语句中的 RETURN换成DELETE即可。
//(1)删除所有的节点
MATCH(n) DELETE n

//(2)删除指定标签中,某个指定属性的节点
MATCH(n:User{userName:'胡涛1'}) DELETE n

在这里插入图片描述

3.4修改节点

语法同样和查询语句类似,因为无论查询、删除、修改,我们都是用 match来匹配的
查询:match ( 节点) return 节点
删除:match ( 节点) delete 节点
修改:match ( 节点) set 节点的属性

//将胡涛1的年龄修改为18岁,并返回修改结果
MATCH (u:User {userName: '胡涛1'}) SET u.userAge = 18 RETURN u

在这里插入图片描述

4关系操作

4.1创建关系

准备工作:提前创建好两个不同节点,这两个节点,可以是同标签,也可以不同标签

//准备User节点
CREATE (n1:User{userName:'小跟班', userAge:28, userSex:'男'}),
(n2:User{userName:'西子', userAge:28, userSex:'女'}),
(n3:User{userName:'念念', userAge:28}),
(n4:User{userName:'老司')

在这里插入图片描述

语法规则CREATE (节点1) - [:关系] 箭头 (节点2)
箭头

  1. –>:表示从一个节点指向另一个节点的有向关系。例如,(a) --> (b) 表示从节点 a 指向节点 b 的有向关系(一个横杠,一个箭头)
  2. <–:表示从一个节点指向另一个节点的相反方向的有向关系。例如,(a) <-- (b) 表示从节点 b 指向节点 a 的有向关系(一个横杠,一个箭头)
  3. –:表示表示两个节点之间没有方向性的关系,即无向关系。例如,(a) – (b) 表示节点 a 和节点 b 之间的无向关系(两个横杆)

注意:Neo4J中,关系的创建不能是无向的,但是查询和使用可以

CREATE (节点1) - [:关系] -> (节点2)

//(1)创建a指向b的关系
MATCH (a:User{userName:'西子'}), (b:User{userName:'小跟班'}) CREATE (a)-[:老公]->(b)

这里我们直接创建了一个没有任何属性的关系,这个关系就叫做老公,效果如下所示
在这里插入图片描述
CREATE (节点1) - [:关系{属性}] -> (节点2)

//(2)创建a指向b的关系,并且包含属性
MATCH (a:User{userName:'西子'}), (b:User{userName:'念念'}) CREATE (a)-[:RELATION{name:'闺蜜'}]->(b)

这里我们创建一个关系,该关系叫做RELATION,并且有个属性name,name为闺蜜
在这里插入图片描述
CREATE (节点1) <- [:关系{属性}] - (节点2)

//(4)创建两个关系:(a->b)  (c<-c)
MATCH (a:User{userName:'西子'}), (b:User{userName:'老司'}), (c:User{userName:'念念'})
CREATE (a)-[:RELATION{name:'哥们'}]->(b),(c)<-[:RELATION{name:'媳妇'}]-(b)

最后我们得到如下这么一个关系
在这里插入图片描述
为了方便查看,我们选择RELATION关系呈现时,选择name属性,同样对于User节点,我们也可以选择需要展示的属性,最终效果如下所示
在这里插入图片描述

4.2查询关系

语法规则:MATCH (节点1) - [:关系] -> (节点2)

//(1)查看所有关系
MATCH ()-[r]-() RETURN DISTINCT r

在这里插入图片描述

//(2)查询指定的关系类型,以及指定的关系属性
MATCH ()-[r:RELATION{name:'媳妇'}]-() RETURN DISTINCT r

在这里插入图片描述

//(3)查询指定类型的关系的节点
MATCH (n1)-[r:RELATION]-(n2) RETURN n1,n2

前面两个查询,我们都是return关系,在这里我们return的节点n1和n2,我们不难发现,在这里我们返回的节点-关系-节点
当我们只返回关系时,只有关系的文本或者表格
当我们只返回节点时,是可以把关系一并返回的,并且可以构成一个图

在这里插入图片描述

//(4)查询指定类型的关系的节点的属性和节点
MATCH (n1)-[r:RELATION]-(n2) RETURN n1.userName,n2

这里,节点1我们返回用户名,节点2整个返回,依然可以看到,还能形成一个图。
在这里插入图片描述
查看table,我们可以发现,节点1确实只返回了用户名,而节点2返回了所有的属性,但是,我们也并没有找到关于n1和n2之间的关系,但是n1和n2确实在关系拓扑图中能看到。
在这里插入图片描述

这是因为Neo4j 是一个图数据库,它的数据模型是基于节点和关系的图形结构,其中节点表示实体,关系表示实体之间的连接。当执行一个查询并返回节点时,Neo4j 将返回所有与查询结果相关的节点,并将这些节点按照它们之间的关系组织成一个图形结构。
即使在查询中没有返回关系,Neo4j 仍然可以根据节点之间的关系来构建图形结构。这是因为关系在 Neo4j 中是由节点来表示的,每个关系都包含指向起始节点和结束节点的引用。因此,当返回节点时,Neo4j 可以通过这些节点之间的关系引用来构建图形结构。

需要注意的是单纯使用cypher查询的话,是不会构成关系图的,构成这个关系图拓扑是Neo4j Browser这个工具为我们画的

4.3删除关系

删除语法和查看语法类似,区别在查看是RETURN,删除是DELETE
语法规则:MATCH (节点1) - [r:关系] -> (节点2) DELETE r

//(1)删除查询出来的关系r
MATCH (f:User{userName:'老司'})
-[r:RELATION{name:'媳妇'}]-
(s:User{userName:'念念'}) 
DELETE r

//(2)删除所有关系r
MATCH ()-[r]-() DELETE r

在这里插入图片描述
删除老司和念念之间的关系后,在查看,就发现他们两个之间关系没了
在这里插入图片描述

4.4修改关系

//(1)我们把删除掉的关系创建回来
MATCH (a:User{userName:'念念'}), (b:User{userName:'老司'})
CREATE (a)<-[:RELATION{name:'媳妇'}]-(b)

//(2)接着我们将关系中的name属性,改成小心肝
MATCH (a:User{userName:'念念'})-[r:RELATION{name:'媳妇'}]-(b:User{userName:'老司'}) set r.name='小心肝'
return a,b

在这里插入图片描述
至此,相信你对neo4j和cypher的基本使用有了一定的认识。接下来我们会详细的学习cypher的语法

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/780858.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Unity进阶-ui框架学习笔记

文章目录 Unity进阶-ui框架学习笔记 Unity进阶-ui框架学习笔记 笔记来源课程&#xff1a;https://study.163.com/course/courseMain.htm?courseId1212756805&_trace_c_p_k2_8c8d7393c43b400d89ae94ab037586fc 最上面的管理层&#xff08;canvas&#xff09; using System…

数仓学习---12、数仓开发之ADS层

星光下的赶路人star的个人主页 知世故而不世故 是善良的成熟 文章目录 1、数仓开发之ADS层1.1 流量主题1.1.1 各渠道流量统计1.1.2 路径分析 1.2 用户主题1.2.1 用户变动统计1.2.2 用户留存率1.2.3 用户新增活跃统计1.2.4 用户行为漏斗分析1.2.5 新增交易用户统计 1.3 商品主题…

Sentinel 规则持久化到 Nacos

一、Sentinel规则管理模式&#x1f349; Sentinel的控制台规则管理有三种模式&#xff1a; 原始模式&#x1f95d; 原始模式&#xff1a;控制台配置的规则直接推送到Sentinel客户端&#xff0c;也就是我们的应用。然后保存在内存中&#xff0c;服务重启则丢失 pull模式&#…

【重点:单例模式】特殊类设计

请设计一个类&#xff0c;只能在堆上创建对象 方式如下&#xff1a; 将构造函数设置为私有&#xff0c;防止外部直接调用构造函数在栈上创建对象。向外部提供一个获取对象的static接口&#xff0c;该接口在堆上创建一个对象并返回。将拷贝构造函数设置为私有&#xff0c;并且…

了解 3DS MAX 3D摄像机跟踪设置:第 2 部分

推荐&#xff1a; NSDT场景编辑器助你快速搭建可二次开发的3D应用场景 1. 项目设置 步骤 1 打开“后效”。 打开后效果 步骤 2 转到合成>新合成以创建新合成。 将“宽度”和“高度”值分别设置为 1280 和 720。将帧速率设置为 25&#xff0c;将持续时间设置为 12 秒。单…

该虚拟机似乎正在使用中。如果该虚拟机未在使用,请按”获取所有权(T)”按钮获取它的所有权。否则,请按”取消(C)”按钮以防损坏。

文章目录 一、报错原因二、解决办法 一、报错原因 这是因为虚拟机未被正确关闭导致的问题。因此&#xff0c;在以后使用虚拟机时&#xff0c;我们应该确保正常关闭虚拟机系统&#xff0c;以避免出现这类问题。 二、解决办法 根据提示的配置文件位置&#xff0c;找到虚拟机安…

web-Access注入

看到网站上面有asp的就要联想到access数据库 方法一&#xff1a; 1.判断出整型注入 ?id1513 and 12 2.判断出列数为22列 ?id1513 order by 22 3.猜表名 回显正常说明存在这个表&#xff0c;回显不正常的话说明这个表就是不存在的。这里猜到表名为admin ?id1513 and ex…

详解HTTP协议(一)

1、HTTP概述 1、什么是HTTP 超文本传输协议&#xff08;Hyper Text Transfer Protocol&#xff0c;HTTP&#xff09; HTTP是一个基于请求与响应的、无状态的应用层协议&#xff0c;用于在两点之间传输超文本数据&#xff0c;常基于TCP/IP协议传输数据。 设计HTTP的初衷是为…

vmware17 开启虚拟机虚拟化

背景 我们需要在虚拟机里创建虚拟机。 实体机需要再bios里设置硬件设备的虚拟化 vmware软件可以在软件里设置虚拟化 设置虚拟化 现在我们看到是不能设置的&#xff0c;那是因为我现在开着这个虚拟机系统&#xff0c; 需要先关闭&#xff0c;才能对他进行设置。

【ACM】—蓝桥杯大一暑期集训Day5

&#x1f680;欢迎来到本文&#x1f680; &#x1f349;个人简介&#xff1a;陈童学哦&#xff0c;目前正在学习C/C、Java、算法等方向&#xff0c;一个正在慢慢前行的普通人。 &#x1f3c0;系列专栏&#xff1a;陈童学的日记 &#x1f4a1;其他专栏&#xff1a;CSTL&#xff…

【Hypermesh】TetraMesh Panel 常用选项详解

我的主页&#xff1a; 技术邻&#xff1a;小铭的ABAQUS学习的技术邻主页博客园 : HF_SO4的主页哔哩哔哩&#xff1a;小铭的ABAQUS学习的个人空间csdn&#xff1a;qgm1702 博客园文章链接&#xff1a; https://www.cnblogs.com/aksoam/p/17575322.html 结合Hypermesh 2020 帮…

Cesium态势标绘专题-辅助文件

本专题没有废话,只有代码,撸! 提示内容封装Tooltip.ts /** 封装提示内容方法* @Author: Wang jianLei* @Date: 2023-01-17 14:56:53* @Last Modified by: jianlei wang* @Last Modified time: 2023-05-19 17:33:37*/ import CreateRemindertip from ./ReminderTip;const T…

Spring-缓存初步认识

Spring-缓存 简单介绍 缓存是一种介于数据永久存储介质和数据应用之间的数据临时存储介质缓存有效提高读取速度&#xff0c;加速查询效率 spring使用缓存方式 添加依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring…

【1++的C++初阶】之list

&#x1f44d;作者主页&#xff1a;进击的1 &#x1f929; 专栏链接&#xff1a;【1的C初阶】 文章目录 一&#xff0c;什么是list二&#xff0c;构造与析构2.1 结点结构2.2 链表结构2.3 迭代器结构 三&#xff0c;部分重要接口的作用及其实现3.1 迭代器相关的接口3.2 list相关…

uniapp 微信小程序 Picker下拉列表数据回显问题

效果图&#xff1a; 1、template <template><view class"items select-box"><view class"items-text">品牌型号</view><picker change"bindBrandType" :value"brandIndex" :range"brandList"…

线性表之链表

1、链表概述 链表是一种物理存储结构上非连续、非顺序的存储结构&#xff0c;数据元素的逻辑顺序是通过链表中的指针链接次序实现的。 顺序表的存储位置可以用一个简单直观的公式表示&#xff0c;它可以随机存取表中任意一个元素&#xff0c;但插入和删除需要移动大量元素。链式…

【多线程】Synchronize关键字之对象锁和类锁

目录 类锁和对象锁的区别 类锁 对象锁 测试用例 1.m1()和m2()方法都加锁【都为非静态&#xff0c;都加锁互斥执行】 2.m1()加锁&#xff0c;m2()不加锁【都为非静态&#xff0c;互不影响】 3.m3()和m4()都加锁【都为静态&#xff0c;互斥】 4.m3()加锁&#xff0c;m4()不…

WPF快速开发(2):图标库知识点

文章目录 前言知识点windows资源Style:样式Setter:属性继承关系 Trigger:触发器 WPF层级划分数据绑定声明数据上下文绑定数据模板 前言 图标资源下载 iconfont 知识点 windows资源 Window.Resources&#xff1a;资源位置声明X:Key&#xff1a;资源Id&#xff0c;用于前端的…

ARM DAY3 点亮三盏灯

1.汇编代码 .text .global _start _start: //RCC初始化 RCC_INIT://设置GPIOE组使能ldr r0,0x50000A28ldr r1,[r0]orr r1,r1,#(0x1<<4)str r1,[r0]//设置GPIOF组使能 ldr r0,0x50000A28ldr r1,[r0]orr r1,r1,#(0x1<<5)str r1,[r0]//LED1灯初始化 LED1_INIT://设置…

WebLLM项目:在浏览器中运行LLM聊天机器人

大家好&#xff0c;基于LLM的聊天机器人可以通过前端访问&#xff0c;而且它们涉及到大量且昂贵的服务器端API调用。但如果可以让LLM完全在浏览器中运行——利用底层系统的计算能力呢&#xff1f;这样&#xff0c;LLM的全部功能都将在客户端可用——无需担心服务器的可用性、基…