neo4j——圖數據庫初探

圖數據庫neo4j初探(下載地址:http://neo4j.org/

本篇將初步介紹一下圖數據庫neo4j,將分一下幾點介紹:什麼是neo4j、neo4j作用、neo4j用法簡單介紹

1、什麼是neo4j

neo4j是一種圖數據庫,同時它也是一種嵌入式數據庫。它對圖數據是以節點和邊(關係)模式進行存儲。每個節點可以包含一系列信息,通過Node類裏面的setProperty()方法對節點信息進行存儲,Node也可以使用createRelationshipTo()方法實現個節點和其他節點的聯繫,並且該方法返回的是一個Relationship對象,我們也可以對Relationship設置屬性,也就是節點和節點之間的關係屬性。什麼叫關係屬性?例如:person1àperson2,person1和person2的關係可以是朋友也可以是同學還可以是親人,這裏的朋友、同學、親人就是這裏的Relationship的屬性。那麼關係屬性就是描敘兩個節點之間的關係類型。這就方便在對節點進行查找的時候對節點進行過濾。如下圖:


2、neo4j作用

上面對neo4j進行了簡單的介紹,可知neo4j是一種對圖數據進行存儲,是一種嵌入式數據庫。它可以將複雜的圖數據以節點和邊形式存儲。例如:在我們現實社會中人與人之間的關係,這就是一個複雜的圖,朋友也可以是多種多樣的,怎樣描敘這樣複雜的圖呢?Neo4j提供了比較簡單的描敘方式。如圖:


就上面的圖可以根據neo4j提供的方法獲取第一層朋友和第二層朋友:   TraversalDescriptiontd = Traversal.description().breadthFirst().relationships(RelTypes.KNOWS, Direction.OUTGOING).filter(Traversal.returnAllButStartNode() );    上面的代碼所執行的是:同個一個事務獲取一個事務描敘,然後根據這個事務描敘在一存儲的圖中過濾出我們想要的節點,這個事務描敘第一個是進行廣度優先搜索(breadthFirst),接下類對節點關係進行過濾。Direction是指定關係的方向,RelTypes就是關係的類型。這樣就可以獲得相應的結果。

3、neo4j用法簡單介紹

此處就neo4j的一個例子進行講解(如圖):


上面圖是一個部門結構圖,這個在我們現實生活中也是比較常見的。如:我們學校,它就是一個由各個部門構成的。如何對這種圖進行查找,以獲得我們想要的信息呢?

1)、獲得各個部門的名:

TraversalDescription td =Traversal.description().breadthFirst().relationships(RoleRels.ROOT, Direction.INCOMING).relationships(RoleRels.PART_OF, Direction.INCOMING).filter(Traversal.returnAllButStartNode());

2)、獲得所有的admin

TraversalDescription td =Traversal.description().breadthFirst().relationships(RoleRels.PART_OF, Direction.INCOMING).relationships(RoleRels.MEMBER_OF, Direction.INCOMING).filter(Traversal.returnAllButStartNode() );

 3)、更具個人信息獲得他所在的所有部門

  Node jale = getUserByName( "Jale" );

 TraversalDescription td = Traversal.description().depthFirst().relationships(RoleRels.MEMBER_OF, Direction.OUTGOING).relationships(RoleRels.PART_OF, Direction.OUTGOING).filter(Traversal.returnAllButStartNode() );

 附錄:

 neo4j還提供了兩種遍歷的方式:一種是深度搜索,第二種是廣度搜索。也提供了兩種搜索算法,一種是A*算法,第二種是dijkstra算法。提高了編程人員的工作效率。同時neo4j也有簡歷索引的功能,方便了多節點的查找。

謝謝瀏覽!本篇到此 結束!


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章