当前位置: 首页 > news >正文

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

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的语法

相关文章:

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

1命名规范 名称应以字母字符开头&#xff0c;不以数字开头&#xff0c;名称不应包含符号&#xff0c;下划线除外可以很长&#xff0c;最多65535( 2^16 - 1) 或65534字符&#xff0c;具体取决于 Neo4j 的版本名称区分大小写。:PERSON和:Person是:person三个不同的标签&#xff…...

ChatGPT:人工智能交互的未来之光

一、ChatGPT&#xff1a;开启自然语言交流新纪元 ChatGPT 是基于 GPT&#xff08;生成式预训练&#xff09;技术的最新版本&#xff0c;它采用深度学习模型&#xff0c;通过在大规模文本数据上的预训练来理解自然语言&#xff0c;并生成具有连贯性和合理性的回复。ChatGPT 是一…...

128最长连续数组

题目描述 最长连续序列 https://leetcode.cn/problems/longest-consecutive-sequence/class Solution {public:int longestConsecutive(vector<int>& nums) {unordered_set<int> st(...

redis 1

shell 1&#xff1a;安装1. 源码安装&#xff08;CENTOS&#xff09; 2.999:可能会出现得问题1. 编译出错 1&#xff1a;安装 1. 源码安装&#xff08;CENTOS&#xff09; 官方下载源码包 wget https://download.redis.io/redis-stable.tar.gz # 安装依赖 yum install gcc解压…...

vue+Element项目中v-for循环+表单验证

如果在Form 表单里有通过v-for动态生成&#xff0c;如何设置验证呢&#xff1f; <el-form ref"ruleFormRef" :model"ruleForm" status-icon :rules"rules" label-width"120px"class"demo-ruleForm" hide-required-aster…...

Day 66-68 主动学习之ALEC

代码&#xff1a; package dl;import java.io.FileReader; import java.util.*; import weka.core.Instances;/*** Active learning through density clustering.*/ public class Alec {/*** The whole dataset.*/Instances dataset;/*** The maximal number of queries that …...

local-path-provisioner与pvc本地磁盘挂载helm部署

1.helm拉取安装包 helm repo add containeroo https://charts.containeroo.ch helm pull containeroo/local-path-provisioner --version 0.0.19 tar -zxvf local-path-provisioner-0.0.19.tgz cd local-path-provisioner mv values.yaml values.yaml.back grep -v "#&qu…...

Visio/PPT/Matlab输出300dpi以上图片【满足标准投稿要求】

1. visio 遵照如下输出选项&#xff0c;另存为tif格式文件时&#xff0c;选择正确输出便是300dpi以上 2. matlab 文件选项选中导出设置&#xff0c;在渲染中选择dpi为600&#xff0c;导出图片即可&#xff0c;科研建议选择tif格式文件 3.ppt 打开注册表&#xff0c;winr键…...

科技UI图标的制作

科技UI图标的制作&#xff0c;效果图如下&#xff1a; 一、新建合成 1、新建合成&#xff0c;命名为合成1&#xff0c;参数设置如下&#xff1a; 2、新建纯色&#xff0c;命名为分形 二、添加分形杂色 1、添加分形杂色 为纯色层“分形”&#xff0c;添加分形杂色&#xff0c…...

微信小程序将接口返回的文件流预览导出Excel文件并转发

把接口url替换就可以用了 exportExcel () {wx.request({url: importMyApply, //这个地方是你获取二进制流的接口地址method: POST,responseType: "arraybuffer", //特别注意的是此处是请求文件流必须加上的属性&#xff0c;不然你导出到手机上的时候打不开&#xff…...

windows 安装 mongodb 数据库

软件下载 访问官方的下载地址&#xff1a; https://www.mongodb.com/try/download/community &#xff0c;然后选择对应的版本进行下载 下载好了之后双击进行安装 软件安装 1、点击 next 点击下一步 2、勾选接受协议&#xff0c;点击 next 3、第三页有两个选项&#x…...

业务不打烊:解决软件系统升级痛点的新方法

数字化时代&#xff0c;随着用户对产品性能和功能要求的不断提升&#xff0c;应用服务升级成了企业保持竞争力的关键之一。然而&#xff0c;传统的应用服务升级往往会给用户带来不必要的中断和不便&#xff0c;这种“伤筋动骨”的升级方式已经无法满足日益增长的用户需求&#…...

csdn新星计划vue3+ts+antd赛道——利用inscode搭建vue3(ts)+antd前端模板

文章目录 ⭐前言⭐利用inscode免费开放资源&#x1f496; 在inscode搭建vue3tsant项目&#x1f496; 调整配置&#x1f496; antd 国际化配置&#x1f496; 用户store&#x1f496; 路由权限&#x1f496; 预览 ⭐结束 ⭐前言 大家好&#xff0c;我是yma16&#xff0c;本文分享…...

通过 CSS 的样式实现语音发送动效类似声音震动的效果

实现效果&#xff1a;一般用于发送语音的时候&#xff0c;出现动画效果 //模版部分 <view class"musical-scale"><view class"scale"><view class"em" v-for"(item,index) in 15" :key"index"></view…...

【C#】.Net Framework框架使用JWT

2023年&#xff0c;第31周&#xff0c;第2篇文章。给自己一个目标&#xff0c;然后坚持总会有收货&#xff0c;不信你试试&#xff01; 本篇文章主要简单讲讲&#xff0c;.Net Framework框架下使用JWT的代码例子&#xff0c;以及他们的基本概念。 2002年微软发布了.net framewo…...

SQL高级教程第三章

SQL CREATE DATABASE 语句 CREATE DATABASE 语句 CREATE DATABASE 用于创建数据库。 SQL CREATE DATABASE 语法 CREATE DATABASE database_name SQL CREATE DATABASE 实例 现在我们希望创建一个名为 "my_db" 的数据库。 我们使用下面的 CREATE DATABASE 语句&…...

vue 3.0 下载本地pdf文件

使用a标签,把pdf文件放到public文件夹下面 <el-form label-width"160px"> <el-form-item label"使用手册"> <div class"form-item-static"> <a href"/使用手册.pdf" target"_blank" class"link&q…...

平板用的触控笔什么牌子好?ipad第三方电容笔推荐

随着技术的发展&#xff0c;出现了各种各样的平板电容笔。一支好的电容笔&#xff0c;不但可以极大地提升我们的工作效率&#xff0c;还可以极大地提升我们的学习效果。平替的电容笔&#xff0c;无论是在技术方面&#xff0c;还是在质量方面&#xff0c;都还有很大的提升空间&a…...

【Unity2D】相机移动以及设置相机边界

添加相机 添加相机时&#xff0c;首先需要在unity中添加 Cinemachine 包 第一次使用这个包时&#xff0c;需要在Package Manager中搜索并安装 安装Camera Mechine包后&#xff0c;添加2D Camera 设置跟随对象为Ruby &#xff08;从Hierarchy中将Ruby拖动到Follow中&#xff0…...

和chatgpt学架构04-路由开发

目录 1 什么是路由2 如何设置路由2.1 安装依赖2.2 创建路由文件2.3 创建首页2.4 编写HomePage2.5 更新路由配置2.6 让路由生效 3 测试总结 要想使用vue实现页面的灵活跳转&#xff0c;其中路由配置是必不可少的&#xff0c;我们在做开发的时候&#xff0c;先需要了解知识点&…...

Spring MVC异常处理【单个控制异常处理器、全局异常处理器、自定义异常处理器】

目录 一、单个控制器异常处理 1.1 控制器方法 1.2 编写出错页面 1.3 测试结果 二、全局异常处理 2.1 一个有异常的控制器类 2.2 全局异常处理器类 2.3 测试结果 三、自定义异常处理器 3.1 自定义异常处理器 3.2 测试结果 往期专栏&文章相关导读 1. Maven系列…...

使用3ds Max粒子系统创建飞天箭雨特效场景

推荐&#xff1a; NSDT场景编辑器助你快速搭建可二次开发的3D应用场景 1. 设置箭头 步骤 1 打开 3ds Max。 打开 3ds Max 步骤 2 我使用多边形建模技术制作了一个简单的箭头&#xff0c;我将 在教程中使用。.max您可以从 下载部分。 箭头.max 步骤 3 将此箭头重命名为静态…...

【朴素贝叶斯实例】

朴素贝叶斯对新闻进行分类 朴素贝叶斯算法是一种常用的文本分类方法&#xff0c;特别适用于自然语言处理任务&#xff0c;如新闻分类。在这篇博客中&#xff0c;我们将使用Python的scikit-learn库来实现朴素贝叶斯算法&#xff0c;并将其应用于新闻分类任务。 数据准备 首先…...

MPAS跨尺度、可变分辨率模式

跨尺度预测模式&#xff08;The Model for Prediction Across Scales - MPAS&#xff09;是由洛斯阿拉莫斯实验室和美国国家大气研究中心(NCAR)共同开发&#xff0c;其由3个部分组成&#xff0c;分别称为 MPAS-A&#xff08;大气模型&#xff09;、MPAS-O&#xff08;海洋模型&…...

微信小程序对接SSE接口记录

微信小程序对接SSE接口记录 需求&#xff1a;公司项目对接gpt&#xff0c;gpt产生的结果是分段返回&#xff0c;所以要求在产生结果时&#xff0c;有打字机的效果。原本是由定时器调用&#xff0c;后来优化改为服务端使用SSE接口。小程序使用起来比较方便&#xff0c;但是要求…...

Ngrok 的绝佳替代品,内网穿透神器 Serveo

什么是 Serveo Serveo 是一个免费的内网穿透服务&#xff0c;Serveo 可以将本地计算机暴露在互联网上&#xff0c;官方声称其为 Ngrok 的绝佳替代品。 Serveo 其最大优点是使用现有的 SSH 客户端&#xff0c;无需安装任何客户端软件即可完成端口转发。 Serveo 工作原理很简单…...

网络知识点之-路由

路由&#xff08;routing&#xff09;是指分组从源到目的地时&#xff0c;决定端到端路径的网络范围的进程。路由工作在OSI参考模型第三层——网络层的数据包转发设备。路由器通过转发数据包来实现网络互连。虽然路由器可以支持多种协议&#xff08;如TCP/IP、IPX/SPX、AppleTa…...

input 框如何移动光标,设置光标位置?

获取 input 光标位置 const inputDom document.getElementById("input") const selectionStart inputDom.selectionStart设置 input 光标 inputDom.focus() // focus() 异步&#xff0c;所以加了 setTimeout setTimeout(() > {const nextSelection selection…...

linux内核系统调用学习5:SYSCALL_DEFINE<0-6>

系统调用最大参数是6&#xff0c;由下面这个宏定义&#xff0c;位于文件include\linux\syscalls.h #define SYSCALL_DEFINE_MAXARGS 6 SYSCALL_DEFINE0(fork) fork&#xff1a;系统调用名。 SYSCALL_DEFINE1(set_tid_address, int __user *, tidptr) set_tid_address&#x…...

maven镜像仓库配置(多镜像自动切换)

大家在使用IDEA的时候会遇到这样的一个问题&#xff0c;就是在下载源代码和资源文档的时候&#xff0c;有些镜像仓库里面没有源代码和资源文档&#xff0c;然后会导致下载失败。 这时候就需要多个镜像仓库的地址了。 附上我自己的配置文件&#xff1a; <mirrors><!--…...