Neo4j的簡單搭建與使用

來源:互聯網
上載者:User
這是一個建立於 的文章,其中的資訊可能已經有所發展或是發生改變。

Neo4j簡介

Neo4j是一個高效能的,NOSQL圖形資料庫,它將結構化資料存放區在網路上而不是表中。它是一個嵌入式的、基於磁碟的、具備完全的事務特性的Java持久化引擎,但是它將結構化資料存放區在網路(從數學角度叫做圖)上而不是表中。Neo4j也可以被看作是一個高效能的圖引擎,該引擎具有成熟資料庫的所有特性。程式員工作在一個物件導向的、靈活的網路結構下而不是嚴格、靜態表中——但是他們可以享受到具備完全的事務特性、企業級的資料庫的所有好處。

Neo4j安裝(MAC)

  1. 下載

    下載Neo4j Community Edition,下載地址如下

     http://neo4j.org/download

    由於是mac下載,直接下載dmg檔案

  2. 運行

    安裝Neo4j Community Edition並開啟,配置運行資料存放區路徑,配置完畢後點擊start啟動


    運行.jpg
  3. Neo4j的遠程可視化操作

    開啟 options ,找到 .neo4j.conf,取消以下代碼的注釋

     dbms.connectors.default_listen_address=0.0.0.0
  4. 瀏覽器開啟

    如果配置了第三步的Neo4j的遠程可視化操作,則訪問http://0.0.0.0:7474/browser/,沒有就直接存取 http://localhost:7474/browser/。


    訪問地址.jpg

Neo4j使用

  1. 基本的增刪改查

    • 插入節點。插入一個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;
  2. 詳細查詢請查看
    https://neo4j.com/docs/developer-manual/current/cypher/

  3. 通過代碼調用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(); }
  4. 通過代碼調用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

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.