這是一個建立於 的文章,其中的資訊可能已經有所發展或是發生改變。
Neo4j簡介
Neo4j是一個高效能的,NOSQL圖形資料庫,它將結構化資料存放區在網路上而不是表中。它是一個嵌入式的、基於磁碟的、具備完全的事務特性的Java持久化引擎,但是它將結構化資料存放區在網路(從數學角度叫做圖)上而不是表中。Neo4j也可以被看作是一個高效能的圖引擎,該引擎具有成熟資料庫的所有特性。程式員工作在一個物件導向的、靈活的網路結構下而不是嚴格、靜態表中——但是他們可以享受到具備完全的事務特性、企業級的資料庫的所有好處。
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使用
基本的增刪改查
插入節點。插入一個Person類別的節點,且這個節點有一個屬性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);
更新節點。更新一個Person類別的節點,設定新的name。
MATCH (n:Person { name: 'Andres' }) SET n.name = 'Taylor';
刪除節點。Neo4j中如果一個節點有邊相連,是不能單單刪除這個節點的。
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;
查詢兩個節點之間的關係。
MATCH (a:Person { name:'Node A' })-[r]->(b:Person { name:'Node B' }) RETURN type(r);
查詢一個節點的所有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/
通過代碼建立節點
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(); }
通過代碼查詢節點
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