激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

腳本之家,腳本語(yǔ)言編程技術(shù)及教程分享平臺(tái)!
分類導(dǎo)航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務(wù)器之家 - 腳本之家 - Python - 在Python中使用Neo4j數(shù)據(jù)庫(kù)的教程

在Python中使用Neo4j數(shù)據(jù)庫(kù)的教程

2020-06-08 09:44Nigel Python

這篇文章主要介紹了在Python中使用Neo4j數(shù)據(jù)庫(kù)的教程,Neo4j是一個(gè)具有一定人氣的非關(guān)系型的數(shù)據(jù)庫(kù),需要的朋友可以參考下

 一個(gè)快速的REST例子

首先來(lái)看些基本知識(shí)。如果沒(méi)有服務(wù)API,Neo4j就不能支持其他語(yǔ)言。該接口提供一組基于JSON消息格式的RESTful Web服務(wù)和一個(gè)全面的發(fā)現(xiàn)機(jī)制。使用中使用這個(gè)接口的最快和最容易的方法是通過(guò)使用cURL
 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
$ curl http://localhost:7474/db/data/
{
 "extensions" : {
 },
 "extensions_info" : "http://localhost:7474/db/data/ext",
 "neo4j_version" : "2.0.0-M03"
}

從這個(gè)端點(diǎn)返回JSON對(duì)象包含一組資源名稱和URI下可以找到的Cypher端點(diǎn)。在消息載荷中接受傳送來(lái)的Cyper請(qǐng)求并執(zhí)行這些查詢,在HTTP響應(yīng)中返回結(jié)果。

正是這種REST API接口,使得現(xiàn)在已有的各種Neo4j驅(qū)動(dòng)得以建立。py2neo提供了這些REST資源的簡(jiǎn)單封裝,這使Python應(yīng)用程序開(kāi)發(fā)者可以放心使用Neo4j而不用考慮底層的客戶機(jī)-服務(wù)器協(xié)議。

一個(gè)簡(jiǎn)單的應(yīng)用

為實(shí)際驗(yàn)證py2neo,我們將著眼于建立一個(gè)簡(jiǎn)單的用于存儲(chǔ)姓名和電子郵件地址的通訊錄管理系統(tǒng)。我們自然會(huì)使用節(jié)點(diǎn)來(lái)模擬每一個(gè)獨(dú)立實(shí)體,但它是要記住,Neo4j沒(méi)有類型的概念。類型是從周圍的關(guān)系和屬性推斷來(lái)的。

下面的關(guān)系圖中人顯示為紅色、電子郵件地址節(jié)點(diǎn)顯示為藍(lán)色。這些當(dāng)然是純粹的邏輯演示節(jié)點(diǎn),但數(shù)據(jù)本身并沒(méi)有區(qū)別。 

在Python中使用Neo4j數(shù)據(jù)庫(kù)的教程

 我們的應(yīng)用程序?qū)⑼瓿蓛蓚€(gè)功能:添加新的聯(lián)系人信息和檢索聯(lián)系人的完整列表。為此,我們將創(chuàng)建一個(gè)Person類包裝Py2neoNodeobject,這使我們有一個(gè)底層處理的實(shí)現(xiàn)且留出用戶級(jí)的功能。上圖中的ROOT節(jié)點(diǎn)是指上圖中一個(gè)固定的參考點(diǎn),我們沿著這個(gè)點(diǎn)開(kāi)始。

讓我們直接看看代碼。下面是一個(gè)完整的小型應(yīng)用。這個(gè)程序允許添加新的名字與一個(gè)或者更多email地址相連接的以及提供了一個(gè)容易的方式來(lái)顯示這些連接信息的一個(gè)命令行工具。沒(méi)有參數(shù)的運(yùn)行是顯示使用模式,而且這個(gè)唯一的依賴只是需要一個(gè)本地未修改的Neo4j實(shí)例(instance)而已。
 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
#!/usr/bin/env python
# -*- coding: utf-8 -*-
 
from __future__ import print_function
 
import sys
from py2neo import neo4j, node, rel
 
graph_db = neo4j.GraphDatabaseService()
 
class Person(object):
   
  _root = graph_db.get_or_create_indexed_node("reference",
     "contacts", "root")
   
  @classmethod
  def create(cls, name, *emails):
    person_node, _ = graph_db.create(node(name=name),
       rel(cls._root, "PERSON", 0))
    for email in emails:
      graph_db.create(node(email=email), rel(cls._root, "EMAIL", 0),
         rel(person_node, "EMAIL", 0))
    return Person(person_node)
   
  @classmethod
  def get_all(cls):
    return [Person(person.end_node) for person in
       cls._root.match("PERSON")]
   
  def __init__(self, node):
    self._node = node
   
  def __str__(self):
    return self.name + "\n" + "\n".join(" <{0}>"
       .format(email) for email in self.emails)
   
  @property
  def name(self):
    return self._node["name"]
   
  @property
  def emails(self):
    return [rel.end_node["email"] for rel in
       self._node.match("EMAIL")]
 
if __name__ == "__main__":
  if len(sys.argv) < 2:
    app = sys.argv[0]
    print("Usage: {0} add <name> <email>
       [<email>...]".format(app))
    print("    {0} list".format(app))
    sys.exit()
  method = sys.argv[1]
  if method == "add":
    print(Person.create(*sys.argv[2:]))
  elif method == "list":
    for person in Person.get_all():
      print(person)
  else:
print("Unknown command")

在第09行上是第一行Py2neo代碼,用來(lái)創(chuàng)建了一個(gè)GraphDatabaseService對(duì)象。通過(guò)這個(gè),我們就可以訪問(wèn)使用Neo4j server的大多數(shù)功能。可選一個(gè)URI傳遞到這個(gè)構(gòu)造器里,盡管如果什么都沒(méi)有提供,代而取之的是使用默認(rèn)的本地參數(shù)。也就是說(shuō)下面兩行是完全相等的:
 

?
1
2
3
graph_db = neo4j.GraphDatabaseService()
graph_db = neo4j.GraphDatabaseService

第13行介紹了調(diào)用了get_or_create_indexed_node,它提供一種在圖形里創(chuàng)建固定引用點(diǎn)的漂亮方式。傳統(tǒng)的Neo4j索引允許節(jié)點(diǎn)和關(guān)系通過(guò)鍵值對(duì)訪問(wèn),而在這個(gè)代碼里我們使用了帶連接的關(guān)鍵字和root值的引用索引實(shí)例。在第一次執(zhí)行時(shí),會(huì)創(chuàng)建一個(gè)新的節(jié)點(diǎn),而且在隨后的執(zhí)行中,這個(gè)節(jié)點(diǎn)(即root)會(huì)復(fù)用(reused)。

在第17行,我們看見(jiàn)了推薦的節(jié)點(diǎn)和關(guān)系抽象的標(biāo)記,以及接受和使用節(jié)點(diǎn)和關(guān)系抽象的 create方法。任意多的抽象都可以被傳遞到這個(gè)方法中,并且在單個(gè)批處理轉(zhuǎn)換中創(chuàng)建實(shí)體并以指定它們的順序作為一個(gè)列表返回。抽象節(jié)點(diǎn)用 節(jié)點(diǎn)函數(shù)表示并帶有一些屬性,然而抽象關(guān)系使用rel函數(shù)接受一個(gè)起始節(jié)點(diǎn),類型和終止節(jié)點(diǎn)。上下文中,其他節(jié)點(diǎn),關(guān)系起始和終止節(jié)點(diǎn)可能整合引用到在其他批處理中其他節(jié)點(diǎn)。在我們的例子中,我們把根節(jié)點(diǎn)連接到新創(chuàng)建的person節(jié)點(diǎn),否則就作為項(xiàng)目0(item 0)了。


這次我們?cè)诘?4行和38行上以match方法形式和關(guān)系見(jiàn)面[@Lesus 注: oschina代碼行數(shù)有問(wèn)題。對(duì)應(yīng)于本文的第28和44行]。它試圖使用一個(gè)特殊的條件集合(set)標(biāo)識(shí)關(guān)系,然后使用列表(list)返回它們。這這些示例中,這個(gè)關(guān)系和PERSON關(guān)系相匹配,從root節(jié)點(diǎn)和EMAIL關(guān)系開(kāi)始到所給定的person節(jié)點(diǎn)。和Cypher很相似,用來(lái)查詢包含MATCH關(guān)鍵字的場(chǎng)景。

最后值得注意的一點(diǎn)是在上面的代碼中訪問(wèn)節(jié)點(diǎn)屬性的方式只是其中一種簡(jiǎn)單的方式。Py2neo重寫了標(biāo)準(zhǔn)python的__getitem__和 __setitem__方法,通過(guò)方括號(hào)標(biāo)識(shí)來(lái)方便訪問(wèn)任何屬性。這點(diǎn)在第34和38行上可以看到。[@Lesus 注:對(duì)應(yīng)于本文的第39和44行]

總結(jié)

在那里(代碼行34和38)我們這樣做了,這顯示了它是如何快速簡(jiǎn)易地在JAVA環(huán)境之外拼湊出一個(gè)Neo4j應(yīng)用程序,也顯示了Py2neo是如何通過(guò)REST API來(lái)抽象出大多數(shù)沉重的負(fù)擔(dān)。這里的例子并沒(méi)有解決唯一性,盡管功能上提供了唯一索引和CypherCREATE UNIQUE語(yǔ)句。Django開(kāi)發(fā)者可能也想要考慮一個(gè)層,如Neomodel,它在Py2neo頂層上表示了一個(gè)Djangoesque ORM-style 層。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲性生活免费视频 | 国产精品麻豆一区二区三区 | 日韩av在线影院 | 国产成年人在线观看 | 国产精品久久久久久久久久大牛 | 黄色网址免费入口 | www噜噜偷拍在线视频 | 国产午夜精品久久久 | 黄色作爱视频 | 成人黄色小视频网站 | 免费视频a | 中文字幕综合在线观看 | 一本色道久久综合狠狠躁篇适合什么人看 | 精品成人一区二区三区 | 草草影院地址 | 九九热九九热 | 国产日韩亚洲 | 91成| 亚洲激情91 | 色播视频网站 | 黄色网址入口 | 国产流白浆高潮在线观看 | 性明星video另类hd | 一级在线 | 91看片淫黄大片欧美看国产片 | 欧美不卡三区 | 秋霞a级毛片在线看 | 欧美中文在线 | 日本高清在线播放 | 免费在线观看成人av | 一级α片 | 日本成人在线免费 | 性少妇videosexfreexxx片 | 久久精品国产清自在天天线 | 欧美精品一区二区久久 | 狠狠久久伊人中文字幕 | a视频网站| 成人福利视频在线观看 | 午夜国产在线 | 91福利社在线 | 午夜精品久久久久久毛片 |