Neo4j簡介
Neo4j是一個高性能的,NOSQL圖形數據庫,它將結構化數據存儲在網絡上而不是表中。它是一個嵌入式的、基于磁盤的、具備完全的事務特性的Java持久化引擎,但是它將結構化數據存儲在網絡(從數學角度叫做圖)上而不是表中。Neo4j也可以被看作是一個高性能的圖引擎,該引擎具有成熟數據庫的所有特性。程序員工作在一個面向對象的、靈活的網絡結構下而不是嚴格、靜態(tài)的表中——但是他們可以享受到具備完全的事務特性、企業(yè)級的數據庫的所有好處。
Neo4j安裝(MAC)
-
下載
下載Neo4j Community Edition,下載地址如下
http://neo4j.org/download由于是mac下載,直接下載dmg文件
-
運行
安裝Neo4j Community Edition并打開,配置運行數據存儲路徑,配置完畢后點擊start啟動
運行.jpg -
Neo4j的遠程可視化操作
打開 options ,找到 .neo4j.conf,取消以下代碼的注釋
dbms.connectors.default_listen_address=0.0.0.0 -
瀏覽器打開
如果配置了第三步的Neo4j的遠程可視化操作,則訪問http://0.0.0.0:7474/browser/,沒有就直接訪問 http://localhost:7474/browser/。
訪問地址.jpg
Neo4j使用
-
基本的增刪改查
-
插入節(jié)點。插入一個Person類別的節(jié)點,且這個節(jié)點有一個屬性name,屬性值為Andres
CREATE (n:Person {name : 'Andres'}); -
插入邊。插入一條a到b的有向邊,且邊的類別為Follow
MATCH (a:Person),(b:Person) WHERE a.name = 'Node A' AND b.name = 'Node B' CREATE (a)-[r:Follow]->(b); -
更新節(jié)點。更新一個Person類別的節(jié)點,設置新的name。
MATCH (n:Person { name: 'Andres' }) SET n.name = 'Taylor'; -
刪除節(jié)點。Neo4j中如果一個節(jié)點有邊相連,是不能單單刪除這個節(jié)點的。
MATCH (n:Person { name:'Taylor' }) DETACH DELETE n; -
刪除邊。
MATCH (a:Person)-[r:Follow]->(b:Person) WHERE a.name = 'Node A' AND b.name = 'Node B' DELETE r; -
查詢最短路徑。
MATCH (ms:Person { name:'Node A' }),(cs:Person { name:'Node B' }), p = shortestPath((ms)-[r:Follow]-(cs)) RETURN p; -
查詢兩個節(jié)點之間的關系。
MATCH (a:Person { name:'Node A' })-[r]->(b:Person { name:'Node B' }) RETURN type(r); -
查詢一個節(jié)點的所有Follower。
MATCH (:Person { name:'Taylor' })-[r:Follow]->(Person) RETURN Person.name;
-
詳細查詢請查看
https://neo4j.com/docs/developer-manual/current/cypher/-
通過代碼調用Neo4j(JAVA),詳細調用代碼如下,驅動,請于才網址下載驅動https://neo4j.com/developer/language-guides/
通過代碼創(chuàng)建節(jié)點
private static void Create() { Driver driver = GraphDatabase.driver( "bolt://10.1.43.73", AuthTokens.basic( "neo4j", "1qaz2wsx" ) ); Session session = driver.session(); session.run( "CREATE (a:Book {name:'helloworld'})" ); session.close(); driver.close(); }通過代碼查詢節(jié)點
private static void Query() { Driver driver = GraphDatabase.driver( "bolt://localhost", AuthTokens.basic( "neo4j", "123456" ) );//調用地址,用戶名和密碼 Session session = driver.session(); StatementResult result = session.run( "MATCH (a: Person) WHERE a.name = 'Andres' RETURN a.name AS name" ); while ( result.hasNext() ) { Record record = result.next(); System.out.println( record.get("name").asString() ); } session.close(); driver.close(); } -
通過代碼調用Neo4j(golabg),詳細調用代碼如下,驅動同上
package main import ( "fmt" bolt "github.com/johnnadratowski/golang-neo4j-bolt-driver" ) func main() { driver := bolt.NewDriver() conn, err := driver.OpenNeo("bolt://localhost:7687") if err != nil { panic(err) } defer conn.Close() stmt, err := conn.PrepareNeo("CREATE (n:NODE {foo: {foo}, bar: {bar}})") if err != nil { panic(err) } result, err := stmt.ExecNeo(map[string]interface{}{"foo": 1, "bar": 2.2}) if err != nil { panic(err) } numResult, err := result.RowsAffected() if err != nil { panic(err) } fmt.Printf("CREATED ROWS: %d\n", numResult) // CREATED ROWS: 1 }
參考
http://blog.csdn.net/dyllove98/article/details/8635965
http://www.cnblogs.com/rubinorth/p/5853204.html
http://static.helloworld114.com/pages/exception/1.html

