一. 简介

neo4j是当今最流行的图数据库,基于 节点+关系 的架构,保存了图形数据的基本元素。同时,数据库也支持通过基础数据元素和独特的CQL查询语法,快速方便的检索、构建复杂的图表关系结果。

二. 基础知识

windows安装方法: 安装方法

CQL基本语法:基本语法

三. 实例

我想构建一个父子继承关系的图表结构,以苏洵苏轼家族为例,先建节点node如下:


  1. create(suxun:Person_{name:"苏洵",age:80,sex:"男"})
  2. create(sushi:Person_{name:"苏轼",age:53,sex:"男"})
  3. create(suzhe:Person_{name:"苏辙",age:51,sex:"男"})
  4. create(suxiaomei:Person_{name:"苏小妹",age:45,sex:"女"})
  5. create(susun:Person_{name:"苏孙",age:29,sex:"男"})
  6. create(suxiaosun:Person_{name:"苏重孙",age:6,sex:"女"})

其中有些节点人名为虚构,为了创建实例方便。  因为我数据库中先前已有Person标签名做了其他的测试,为避免重复和歧义,本例中标签名起为"Person_"。

对于节点之间的关系,为 :

苏洵-------|------苏轼 --------------苏孙 ---------------苏重孙

|------苏辙

|------苏小妹

因此创建结构的CQL为:


  1. match(p1:Person_),(p2:Person_)
  2. where p1.name="苏洵" and p2.name = "苏轼"
  3. create (p1) -[parent:Parent{relation:"父亲"}]-> (p2);
  4. match(p1:Person_),(p2:Person_)
  5. where p1.name="苏洵" and p2.name = "苏辙"
  6. create (p1) -[parent:Parent{relation:"父亲"}] -> (p2);
  7. match(p1:Person_),(p2:Person_)
  8. where p1.name="苏洵" and p2.name = "苏小妹"
  9. create (p1) -[parent:Parent{relation:"父亲"}] -> (p2);
  10. match(p1:Person_),(p2:Person_)
  11. where p1.name="苏轼" and p2.name = "苏孙"
  12. create (p1) -[parent:Parent{relation:"父亲"}] -> (p2);
  13. match(p1:Person_{name:"苏孙"}),(p2:Person_{name:"苏重孙"})
  14. 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的搭建和实例使用的更多相关文章

  1. 基于Docker的TensorFlow机器学习框架搭建和实例源码解读

    概述:基于Docker的TensorFlow机器学习框架搭建和实例源码解读,TensorFlow作为最火热的机器学习框架之一,Docker是的容器,可以很好的结合起来,为机器学习或者科研人员提供便捷的 ...

  2. springmvc环境搭建及实例

    一. 软件环境 eclipse-jee-mars-R-win32-x86_64 jdk1.7.0_79 apache-tomcat-7.0.52 spring-framework-3.2.0.RELE ...

  3. SpringMVC笔记——SSM框架搭建简单实例

    落叶枫桥 博客园 首页 新随笔 联系 订阅 管理 SpringMVC笔记——SSM框架搭建简单实例 简介 Spring+SpringMVC+MyBatis框架(SSM)是比较热门的中小型企业级项目开发 ...

  4. monkeyrunner之环境搭建及实例(三)

    Monkeyrunner工具提供了一个API,使用此API写出的程序可以在Android代码之外控制Android设备和模拟器. 一.Monkeyrunner简介 1.MOnkeyrunner相对Mo ...

  5. CENTOS6.6上搭建单实例ORACLE12C

    本文来自我的github pages博客http://galengao.github.io/ 即www.gaohuirong.cn 摘要: 自己在centos6.6上搭建的单实例oracle12c 由 ...

  6. TFS2018环境搭建一单实例安装(适用于小型团队)

    1.服务器配置 阿里云 单核CPU,2GB的RAM,SSD硬盘,安装TFS实例 TFS2018要求SQL Server 2016 (minimum SP1)以上.其要求有以下几点: (1).安装SQL ...

  7. Struts2环境搭建及实例解析

    与struts1框架的使用一样,struts2的环境搭建及使用同样分为以下几个步骤: 1.      引入jar包(这里以struts2.2.3为例),所需jar包有以下几个: a)        s ...

  8. Redis实战篇(一)搭建Redis实例

    今天是Redis实战系列的第一讲,先从如何搭建一个Redis实例开始. 下面介绍如何在Docker.Windows.Linux下安装. Docker下安装 1.查看可用的 Redis 版本 访问 Re ...

  9. mysql 在一个实例运行情况下再搭建一个实例

    配置mysql服务 详细步骤,请参考(http://study.lishiming.net/chapter17.html#mysql), 阿铭只把简单步骤写一下. 根据阿铭提供的地址,假如你已经搭建好 ...

随机推荐

  1. leetcode-421-数组中两个数的最大异或值*(前缀树)

    题目描述: 方法一: class Solution: def findMaximumXOR(self, nums: List[int]) -> int: root = TreeNode(-1) ...

  2. PL/SQL创建用户

    步骤一:新建 步骤二:填写信息 对应SQL代码 -- Create the user create user WENT identified by "longrise" defau ...

  3. SpringBoot--Banner的定制和关闭

    SpringBoot项目启动的时候控制台会打印如下信息: 上面红色框框内的“SPRING BOOT”被称为Banner,意为横幅,默认会开启并在控制台打印,其实我们可以修改它的内容和样式,即定制:并选 ...

  4. QT 获取文件的路径、打开文件的弹出对话框

    1.打开获取文件夹路径的对话框 QString filePath = QFileDialog::getExistingDirectory(this, "请选择文件保存路径...", ...

  5. 《DSP using MATLAB》Problem 8.39

    代码: %% ------------------------------------------------------------------------ %% Output Info about ...

  6. 19.SimLogin_case04

    # 利用cookies登录马蜂窝 import requests from lxml import etree session = requests.Session() phone_number = ...

  7. POJ 2398 map /// 判断点与直线的位置关系

    题目大意: poj2318改个输出 输出 a: b 即有a个玩具的格子有b个 可以先看下poj2318的报告 用map就很方便 #include <cstdio> #include < ...

  8. java_网络编程之BS(web案例)

    package BsServersocket; import java.io.*; import java.net.ServerSocket; import java.net.Socket; publ ...

  9. MATLAB 中自定义函数的使用

    MATLAB在文件内部(在函数内部)定义函数,但文件名以开头函数来命名,与Java中每个文件只能有一个公开类,但在文件内部还是可以定义其他非公开类一个道理. 无参函数 do.m function do ...

  10. UMP系统功能 资源隔离