OrientDB 图计算框架

OrientDB Doc传送门

图计算框架学习示例

概念

  • 图(Graph)G=(V,E)

    V是非空集合的顶点集,E是V中顶点构成的无序二元组的边集合。 G的边集合数范围: 0≤E≤N(N-1)/2

E = {(V^1,V^2),(V^1,V^3)......(V^i,V^j)}
  • 点(Vertex)
  • 边(Edge)

安装步骤 点击下载

开发环境 Host 172.30.13.197

cd /home/work/local/orientdb-community-2.2.12
./bin/server.sh &

Web管理后台:http://172.30.13.197:2480/studio/index.html

  • 首次启动时会提醒建立Root账户密码

SQL基本操作

1.新增VerTex

CREATE VERTEX V SET name="user01",sex="M",age="25";
CREATE VERTEX V SET name="user02",sex="F",age="23";

2.删除VerTex

DELETE VERTEX V WHERE name="user01";

3.新增Edge

CREATE EDGE E FROM #1:1 TO #1:2 SET name="friend";

4.删除Edge

DELETE EDGE E WHERE name="friend";

删除某个VerTex顶点时,其附加的Edge自动失效

代码示例(java)

小朱25岁,出生在教师家庭并且有个姐姐小田,他现在奋斗在帝都。
那么SQL是这样滴!!!

CREATE VERTEX V SET name="小朱",sex="男",age="25";
CREATE VERTEX V SET name="小田",sex="女",age="27";
CREATE EDGE E FROM #9:0 TO #10:0 SET name="sisiter";
CREATE EDGE E FROM #10:0 TO #9:0 SET name="brother";
Select  from V where name in ['小朱',"小田"];


* select 在 Graph 页面查询会自动渲染出关系结果

小朱还有一个可爱的女盆友叫小刘

CREATE VERTEX V SET name="小刘",sex="女",age="23";
CREATE EDGE E FROM #9:0 TO #11:0 SET name="lover";
CREATE EDGE E FROM #11:0 TO #9:0 SET name="lover";

小朱目前工作在企业ABC,他有一堆同事小马、小龚、小微…..

CREATE VERTEX V SET name="ABC";
CREATE VERTEX V SET name="小马",sex="男",age="29",company="ABC";
CREATE VERTEX V SET name="小龚",sex="男",age="28",company="ABC";
CREATE VERTEX V SET name="小微",sex="女",age="24",company="ABC";
UPDATE V SET company = 'ABC' WHERE name='小朱'
CREATE EDGE E FROM (select from V where company='ABC') TO (select from V where name ='ABC') SET name="employee";

小朱目前跟不同同事合作完成了如下项目:PROJECT-1,PROJECT-2,PROJECT-3…..

CREATE VERTEX V SET name="PROJECT-1",type='JAVA',starttime='2016/01/01';
CREATE VERTEX V SET name="PROJECT-2",type='JAVA',starttime='2016/01/01';
CREATE VERTEX V SET name="PROJECT-3",type='JAVA',starttime='2016/01/01';CREATE EDGE E FROM (select from V where name in ['小朱','小马','小微']) TO (select from v where name='PROJECT-1') SET name="work";
CREATE EDGE E FROM (select from V where name in ['小朱','小马','小微','小龚']) TO (select from v where name='PROJECT-2') SET name="work";
CREATE EDGE E FROM (select from V where name in ['小朱','小马','小龚']) TO (select from v where name='PROJECT-3') SET name="work";

  • 所有点和边缘均继承祖先V、E对象,不能方便的通过语句进行筛选,不推荐直接创建V、E记录。

改造以上实例,用不同的关系对象表示

上图出现了两种对象(公司,人,项目)……划分规则,看心情
有5类关系(情侣,姐,弟,雇员,合作)
莫名其妙有了V{Company,Preson,Project},E{Lover,sisiter,brother,employee,work}

CREATE CLASS Company EXTENDS V;
CREATE CLASS Project EXTENDS V;
CREATE CLASS Preson EXTENDS V;
CREATE CLASS Lover EXTENDS E;
CREATE CLASS Sisiter EXTENDS E;
CREATE CLASS Brother EXTENDS E;
CREATE CLASS Employee EXTENDS E;
CREATE CLASS Work EXTENDS E;CREATE VERTEX Preson SET name="小朱",sex="男",age="25",company="Lianjia";
CREATE VERTEX Preson SET name="小刘",sex="女",age="23";
CREATE VERTEX Preson SET name="小田",sex="女",age="27";
CREATE VERTEX Company SET name="Lianjia";
CREATE VERTEX Preson SET name="小马",sex="男",age="29",company="Lianjia";
CREATE VERTEX Preson SET name="小龚",sex="男",age="28",company="Lianjia";
CREATE VERTEX Preson SET name="小微",sex="女",age="24",company="Lianjia";
CREATE VERTEX Project SET name="PROJECT-1",type='JAVA',starttime='2016/01/01';
CREATE VERTEX Project SET name="PROJECT-2",type='JAVA',starttime='2016/01/01';
CREATE VERTEX Project SET name="PROJECT-3",type='JAVA',starttime='2016/01/01';#把以前的顶点移动到每个具体的类别
#MOVE VERTEX(SELECT FROM V WHERE name='ABC') TO CLASS:Company;#创建情侣关系
CREATE EDGE Lover FROM (select from Preson where name='小朱') TO (select from Preson where name='小刘');
CREATE EDGE Lover FROM (select from Preson where name='小刘') TO (select from Preson where name='小朱');#创建姐弟关系
CREATE EDGE Sisiter FROM (select from Preson where name='小朱') TO (select from Preson where name='小田');
CREATE EDGE Brother FROM (select from Preson where name='小田') TO (select from Preson where name='小朱');#创建雇佣关系
CREATE EDGE Employee FROM (select from Preson where company='Lianjia') TO (select from Company where name ='Lianjia');#创建项目关系
CREATE EDGE Work FROM (select from Preson where name in ['小朱','小马','小微']) TO (select from Project where name='PROJECT-1');
CREATE EDGE Work FROM (select from Preson where name in ['小朱','小马','小微','小龚']) TO (select from Project where name='PROJECT-2');
CREATE EDGE Work FROM (select from Preson where name in ['小朱','小马','小龚']) TO (select from Project where name='PROJECT-3');

OrientDB 图状数据库示例相关推荐

  1. 系统设计之图状数据模型

    图状数据模型 多对多关系是不同数据模型之间的重要区别特征.若数据大多是一对多(树结构数据)或记录之间无关系,则文档模型最合适.但若多对多关系的数据很常见,关系模型能处理简单的多对多,但随数据之间关联复 ...

  2. OrientDB图遍历SQL之MATCH

    OrientDB图遍历SQL之MATCH 本文介绍的MATCH语法是基于OrientDB3.0.x版本,所有的SQL在OrientDB3.0.4社区版本自带的数据库demodb下试验,数据模型请参考d ...

  3. 知识图:从图和数据库中获取知识

    知识图:从图和数据库中获取知识 知识图到底是什么,以及关于它们的所有炒作是什么?如果想成为世界各地的Airbnbs,Amazon,Google和LinkedIn,那么学会区分真实的炒作,定义不同类型的 ...

  4. python导入txt文件并绘图-Python实现读取txt文件并画三维图简单代码示例

    记忆力差的孩子得勤做笔记! 刚接触python,最近又需要画一个三维图,然后就找了一大堆资料,看的人头昏脑胀的,今天终于解决了!好了,废话不多说,直接上代码! #由三个一维坐标画三维散点 #codin ...

  5. python读取txt文件代码-Python实现读取txt文件并画三维图简单代码示例

    记忆力差的孩子得勤做笔记! 刚接触python,最近又需要画一个三维图,然后就找了一大堆资料,看的人头昏脑胀的,今天终于解决了!好了,废话不多说,直接上代码! #由三个一维坐标画三维散点 #codin ...

  6. lmbs PHP,PHP的GD2函数创建折线图源码示例

    PHP的GD2函数创建折线图源码示例 代码来自 codego.net/tags/4/1/ if(!is_numeric($data[$i])) die("error id:1"); ...

  7. 孔雀东南飞用mysql存储_PowerDesigner使用建议(完整版) 用实体关系图进行数据库建模...

    1.Powerdesigner使用建议 1.1业务规则的使用(Business Rule) 对于一些业务逻辑可能出现在多个数据表中,建议封装成Business Rule,这样便于业务逻辑的重新使用,也 ...

  8. Bootstrap4+MySQL前后端综合实训-Day04-AM【新闻管理手机端页面+数据库操作(PowerDesigner 图形化数据库设计软件、SQLyog软件)】

    [Bootstrap4前端框架+MySQL数据库]前后端综合实训[10天课程 博客汇总表 详细笔记] 目   录 W3C标准盒子模型和IE盒子模型的区别 Bootstrap4--新闻管理手机端页面 菜 ...

  9. 使用 read_graphviz 将 GraphViz Dot 文本图加载到 BGL adjacency_list 图的简单示例

    boost::graph模块使用 read_graphviz 将 GraphViz Dot 文本图加载到 BGL adjacency_list 图的简单示例 实现功能 C++实现代码 实现功能 boo ...

最新文章

  1. 如何通过 Scratch 教小朋友编程思维?
  2. python requests 发送 上传 多个文件
  3. 10g TNS 13541 监听错误 tnsping可以但是conn system/manager@mult1.net 报错
  4. Vue中使用a标签实现点击在新标签页中打开实现照片预览
  5. 08r2系统服务器开索引,SQLSERVER2008R2正确使用索引
  6. tf.layers.flatten
  7. c99什么意思_C语言中-是什么意思啊?
  8. 程序员入职后千万不要沾沾自喜,不注意这一点,将来很可能后悔!
  9. vue函数input输入值即请求,优化为用户输入完成之后再请求
  10. Python设置常量不可修改的办法
  11. nrf52832开发配置文件小记
  12. Vert.x(vertx) 认证和授权
  13. 关于Bean Validation
  14. JavaWeb项目架构之Kafka分布式日志队列
  15. 小型超市管理系统(JAVA,JSP,SSH,MYSQL)
  16. lpx寒假作业案例10
  17. android 按钮带图标 阴影_Android Material Design系列之FloatingActionButton和Snackbar
  18. 用例图包含关系、扩展关系、泛化关系解析
  19. python内存持续增长_Python 进程内存增长解决方案
  20. 4月中国App开发商推广排行榜

热门文章

  1. 阿里面试官对面试者的忠告
  2. 重学java——套娃
  3. Airsim中运行OpenVINS和VINS_Fusion
  4. 权重 缩写 英文_常用英语术语缩写--采购
  5. (转)纵观国内外证券公司IT发展史
  6. ARM指令——跳转指令
  7. 个人空间的编辑个人资料案例(简单介绍 仅供参考)
  8. SQL和Oracle获取每周、每月、每年第一天和最后一天
  9. 利用注册表修改文件关联
  10. Linux 文件隐藏权限