简介

pyorient是orientdb的python库

该库提供两种访问orientdb的方式:1、client 的方式

2、ogm 的方式(类似于ORM)

由于OGM 封装了client,且由于OGM 易于理解,操作简单,所以,这里主要介绍OGM。

创建/连接数据库

导入OGM 所需模块

from pyorient.ogm import Graph, Config

实例化 graph

config = Config.from_url('/localhost/test','root','root')
graph = Graph(config,'admin','admin')

 :

  • config 中的两个 root 分别为orientdb 实例的用户名和密码。类似于如下命令

orientdb > connect remote:localhost root root

graph 中的两个 admin 即想要连接的数据库的用户名和密码

  • 由于Graph() 会调用open 方法,所以,如果数据库中没有将要连接的数据库,那么就会创建一个新的,相应的数据库。

操作数据库

映射

和ORM类似,OGM会将 python 代码中的 class 映射到orientdb中的class。相当于关系型数据库中的表;python中class的属性即为orientd中class的property。即相当于关系型数据库中表的字段/列

想要将python中的class 映射到orientdb 中的class,需要将python中的class进行注册。

代码如下:

from pyorient.ogm.declarative import declarative_node, declarative_relationship

Node = declarative_node()
Relationship = declarative_relationship()

class Person(Node):
    pass

class Likes(Relationship):
    pass

graph.create_all(Node.registry)
graph.create_all(Relationship.registry)

  • 每一次调用declarative_node( ) 和 declarative_relationship( ) 都会生成相应的注册表。其实Node和Relationship是两个基类。
  • create_all( ) 命令就会在orientdb中创建相应的class,如果该class已经存在,那么就会更新该class。

Boker (代理)

OGM 拥有多层映射。

上面提到的python class 到 orientdb class 是一层映射。另一层映射是python class 的object(对象) 和orientdb中具体的 vertex 和 edge 之间的映射。Boker 即工作在这一层。该层映射成功后,会自动为每一个class 创建个一个boker对象。需要注意的是vertex类需要有element_plural 属性,relationship类需要有 label 属性。

代码如下:

class Foo(Node):
    element_plural = 'foos'
    name = String()
class Friend(Relationship):
    label = 'friends'
graph.include(Node.registry)   
graph.foos.create(name='Bar')
Foo.objects.create(name='Baz')

find_bar = graph.foos.query(name='Bar')

  • graph.foos 和Foo.objects 都是一样的,都是boker对象。
  • Relationship 的子类,在orientdb中 是用 label 来命名类名的。如 Friend 类在数据库中的类名为friends
  • query() 反回的是一个查询集对象。

命令

inE()  outE() bothE()

返回进/出/进出自一个顶点或者类的 边的对象

in_() out() both()

返回 进/出/进出 自一个边的或者类的 顶点的对象。

get_vertex()  get_edge()  get_element()

获取 顶点/边/顶点或者边

element 包括顶点和边两种对象。

create_class()  create_vertex() create_edge() drop_class()

创建 顶点或边/顶点/边 ; 删除类

open()   drop()

打开/关闭一个数据库

 : 调用open( )时,如果该数据库不存在,则自动创建。

调用drop( ) 时,需要有一个已经打开的数据库。

query()

返回一个query对象。具有all count group_by order_by filter 等方法,可以对查询结果进行处理。

update()   clear_registry()

更新python中orientdb对象的元素注册表 /清除元素注册表

字段类型

在OGM中,python类的属性就是orientdb 的property,也就是相当于关系型数据库中的字段/列。在pyorient中,字段类型有 String Boolean Float Date 等类型。这些字段又有如下属性。

name 会覆盖掉 “=” 前面命名的属性名。

nullable 允许为空

readonly 只读

default 默认值

indexed 是否为索引值

unique 是否唯一,如果为真,那么会创建相应的索引。

mandatory 是否强制有值。如果没有设置可以为空,那么默认设定为强制有值。

pyorient的更多相关文章

随机推荐

  1. 【python】序列切片和range函数

    序列的每个元素都可以用2种索引的表达方式,一种是正数索引,另一种是负数索引. 序列切片,作用是访问序列中一定范围的元素,格式“序列名[A:B]”,其中A为所切片的第一个元素的索引号,而B为切片后剩下的 ...

  2. 在doc下面执行zpl语言 Copy 文件名 lpt1

    在doc下面执行zpl语言 Copy 文件名 lpt1 测试斑马条码打印机并口是否能正常通讯: 1.Zebra打印机安装好标签和碳带,且打印机进入Ready状态.2.电脑端用Notepad编写输入如下 ...

  3. BEGIN-4_蓝桥杯_Fibonacci数列

    问题描述 Fibonacci数列的递推公式为:Fn=Fn-+Fn-,其中F1=F2=. 当n比较大时,Fn也非常大,现在我们想知道,Fn除以10007的余数是多少. 输入格式 输入包含一个整数n. 输 ...

  4. Oracle学习操作(5)触发器

    Oracle触发器 一.触发器简介 具备某些条件,由数据库自动执行的一些DML操作行为: 二.语句触发器 现在数据库创建t_book表:t_booktype表:t_book表的typeid存在外键参考 ...

  5. php让页面记住表单提交后的信息方法

    <body> <?php $name = $_POST['name']; echo $name; $gender = $_POST['gender']; echo $gender; ...

  6. ASP.NET Web Pages:C# 和 VB 实例

    ylbtech-.Net-ASP.NET Web Pages:C# 和 VB 实例 1.返回顶部 1. ASP.NET Web Pages - C# 和 VB 实例 通过 C# 和 Visual Ba ...

  7. nginx的日志分析

    1.到NGINX把日志DOWN下来2.用命令cat xxxx.log | egrep '10/Jul/2015:01:[4-5]|2015-07-10 02:0[0-57]'>xxxx2.log ...

  8. [UE4]ue4 c++学习推荐

    我由易到难推荐,不过在此之前还是先看看官方对于VS设置的推荐: https://docs.unrealengine.com/latest/INT/Programming/Development/Vis ...

  9. Web 使用反射获得一个对象的所有get方法

    问题描述: 由于想知道request中包含哪些getter方法,就想通过反射进行遍历,然后输出,结果异常,异常信息: 问题代码: try { outGetter(request); } catch ( ...

  10. mysql 更新(二)安装和基本管理

    03-MySql安装和基本管理   本节掌握内容: MySQL的介绍安装.启动 MySQL破解密码 MySQL中统一字符编码 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目 ...