neo4j的搭建和实例使用
一. 简介
neo4j是当今最流行的图数据库,基于 节点+关系 的架构,保存了图形数据的基本元素。同时,数据库也支持通过基础数据元素和独特的CQL查询语法,快速方便的检索、构建复杂的图表关系结果。
二. 基础知识
windows安装方法: 安装方法
CQL基本语法:基本语法
三. 实例
我想构建一个父子继承关系的图表结构,以苏洵苏轼家族为例,先建节点node如下:
-
create(suxun:Person_{name:"苏洵",age:80,sex:"男"})
-
create(sushi:Person_{name:"苏轼",age:53,sex:"男"})
-
create(suzhe:Person_{name:"苏辙",age:51,sex:"男"})
-
create(suxiaomei:Person_{name:"苏小妹",age:45,sex:"女"})
-
create(susun:Person_{name:"苏孙",age:29,sex:"男"})
-
create(suxiaosun:Person_{name:"苏重孙",age:6,sex:"女"})
其中有些节点人名为虚构,为了创建实例方便。 因为我数据库中先前已有Person标签名做了其他的测试,为避免重复和歧义,本例中标签名起为"Person_"。
对于节点之间的关系,为 :
苏洵-------|------苏轼 --------------苏孙 ---------------苏重孙
|------苏辙
|------苏小妹
因此创建结构的CQL为:
-
match(p1:Person_),(p2:Person_)
-
where p1.name="苏洵" and p2.name = "苏轼"
-
create (p1) -[parent:Parent{relation:"父亲"}]-> (p2);
-
-
match(p1:Person_),(p2:Person_)
-
where p1.name="苏洵" and p2.name = "苏辙"
-
create (p1) -[parent:Parent{relation:"父亲"}] -> (p2);
-
-
match(p1:Person_),(p2:Person_)
-
where p1.name="苏洵" and p2.name = "苏小妹"
-
create (p1) -[parent:Parent{relation:"父亲"}] -> (p2);
-
-
match(p1:Person_),(p2:Person_)
-
where p1.name="苏轼" and p2.name = "苏孙"
-
create (p1) -[parent:Parent{relation:"父亲"}] -> (p2);
-
-
match(p1:Person_{name:"苏孙"}),(p2:Person_{name:"苏重孙"})
-
create (p1) -[parent:Parent{relation:"父亲"}] -> (p2);
其中有两种方法:
- 第一种用where进行节点筛选,例如 where p1.name="苏洵" and p2.name = "苏轼"
- 第二种用属性进行节点筛选,例如match(p1:Person_{name:"苏孙"}),(p2:Person_{name:"苏重孙"})
两种方法都可以达到效果
最终结果为:
match(a)-[r:Parent]->(b) return a, r, b
使用match进行筛选,并且拼装成树状结构:
1. 筛选出子孙绵延四代的树干
match(a)-[r1:Parent]->(b)-[r2:Parent]->(c)-[r3:Parent]->(d) return a, b, c, d
2. 筛选出存在三代子孙的树干
match(a)-[r1:Parent]->(b)-[r2:Parent]->(c) return a, b, c
可以发现,查出来的图形虽然是只有一条链路,但其实代表两条数据,各三级节点,如下
那如果要查询某个节点开始的三级结构呢?
3. 筛选出某个节点为顶点的三代子孙树干
match(a{name:"苏洵"})-[r1:Parent]->(b)-[r2:Parent]->(c) return a, b, c
这样就只筛选得到的是以“苏洵”为顶点的三级结构,依次是“苏洵”-->“苏轼”-->“苏孙”
可看到只有一条数据
原文地址:https://blog.csdn.net/u010086122/article/details/82390945
neo4j的搭建和实例使用的更多相关文章
- 基于Docker的TensorFlow机器学习框架搭建和实例源码解读
概述:基于Docker的TensorFlow机器学习框架搭建和实例源码解读,TensorFlow作为最火热的机器学习框架之一,Docker是的容器,可以很好的结合起来,为机器学习或者科研人员提供便捷的 ...
- springmvc环境搭建及实例
一. 软件环境 eclipse-jee-mars-R-win32-x86_64 jdk1.7.0_79 apache-tomcat-7.0.52 spring-framework-3.2.0.RELE ...
- SpringMVC笔记——SSM框架搭建简单实例
落叶枫桥 博客园 首页 新随笔 联系 订阅 管理 SpringMVC笔记——SSM框架搭建简单实例 简介 Spring+SpringMVC+MyBatis框架(SSM)是比较热门的中小型企业级项目开发 ...
- monkeyrunner之环境搭建及实例(三)
Monkeyrunner工具提供了一个API,使用此API写出的程序可以在Android代码之外控制Android设备和模拟器. 一.Monkeyrunner简介 1.MOnkeyrunner相对Mo ...
- CENTOS6.6上搭建单实例ORACLE12C
本文来自我的github pages博客http://galengao.github.io/ 即www.gaohuirong.cn 摘要: 自己在centos6.6上搭建的单实例oracle12c 由 ...
- TFS2018环境搭建一单实例安装(适用于小型团队)
1.服务器配置 阿里云 单核CPU,2GB的RAM,SSD硬盘,安装TFS实例 TFS2018要求SQL Server 2016 (minimum SP1)以上.其要求有以下几点: (1).安装SQL ...
- Struts2环境搭建及实例解析
与struts1框架的使用一样,struts2的环境搭建及使用同样分为以下几个步骤: 1. 引入jar包(这里以struts2.2.3为例),所需jar包有以下几个: a) s ...
- Redis实战篇(一)搭建Redis实例
今天是Redis实战系列的第一讲,先从如何搭建一个Redis实例开始. 下面介绍如何在Docker.Windows.Linux下安装. Docker下安装 1.查看可用的 Redis 版本 访问 Re ...
- mysql 在一个实例运行情况下再搭建一个实例
配置mysql服务 详细步骤,请参考(http://study.lishiming.net/chapter17.html#mysql), 阿铭只把简单步骤写一下. 根据阿铭提供的地址,假如你已经搭建好 ...
随机推荐
- Django 前后端数据传输、ajax、分页器
返回ORM目录 Django ORM 内容目录: 一.MTV与MVC模式 二.多对多表三种创建方式 三.前后端传输数据 四.Ajax 五.批量插入数据 六.自定义分页器 一.MTV与MVC模式 M ...
- LINUX centos 7.2/7.3 搭建LAMP环境
首先我们先查看下centos的版本信息 #适用于所有的linux lsb_release -a #或者 cat /etc/redhat-release #又或者 rpm -q centos-relea ...
- 8_InlineHook
1 shellcode低2Gb警告.应使用高2GB 稳定 : 在内核挂钩子: 由于每个进程的低2gb 的数据是不同的:所以 在内核挂钩子 因该把 代码 放在 高 2gb. 方法1(申请): 比如 使用 ...
- js字符串去重复
var str="fdafdasfdasfdsfdseeeu"; function te(str){ var hash=[]; var arr=new Array(); var s ...
- 代码执行批量Excel数据导入Oracle数据库
由于基于Oracle数据库上做开发,因此常常会需要把大量的Excel数据导入到Oracle数据库中,其实如果从事SqlServer数据库的开发,那么思路也是一样的,本文主要介绍如何导入Excel数据进 ...
- MySQL高可用(Galera Cluster)
Galera Cluster简介 Galera Cluster是集成了Galera插件的MySQL集群,是一种新型的,数据不共享的,高度冗余的高可用方案,目前Galera Cluster有两个版本,分 ...
- Java-Maven-pom.xml-project-packaging:packaging(war/jar)
ylbtech-Java-Maven-pom.xml-project-packaging:packaging(war/jar) 1.返回顶部 1.packaging 1.1 war <!-- 打 ...
- System.Web.Mvc.HttpPutAttribute.cs
ylbtech-System.Web.Mvc.HttpPutAttribute.cs 1.程序集 System.Web.Mvc, Version=5.2.3.0, Culture=neutral, P ...
- iOS开发之SceneKit框架--SCNLight.h
1.SCNLight简介 用于添加光源,连接到一个节点照亮现场,可以给场景添加不同的灯光,模拟逼真的环境. 2.四种灯光的简介 添加一个box立方体.一个tube圆柱管道和一个地板floor,没有灯光 ...
- Spring的refresh()方法相关异常
如果是经常使用Spring,特别有自己新建ApplicationContext对象的经历的人,肯定见过这么几条异常消息:1.LifecycleProcessor not initialized - c ...