Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up

A thin Ruby wrapper to the Neo4j Rest API

License

NotificationsYou must be signed in to change notification settings

maxdemarzi/neography

Repository files navigation

  • Gem Version
  • Build Status
  • Code Climate
  • Coverage Status

Welcome to Neography

Neography is a thin Ruby wrapper to the Neo4j Rest API, for more information:

If you want to utilize the full power of Neo4j, you will want to use JRuby and the excellent Neo4j.rb gem athttps://github.com/andreasronge/neo4j by Andreas Ronge

Installation

Gemfile

Addneography to your Gemfile:

gem'neography'

And run Bundler:

$ bundle

Manually:

Or installneography manually:

$ gem install'neography'

And require the gem in your Ruby code:

require'rubygems'require'neography'

Read the wiki for information aboutdependencies.

Rake tasks are available for downloading, installing and running Neo4j.

Usage

Configuration and initialization

Configure Neography as follows:

# these are the default values:Neography.configuredo |config|config.protocol="http"config.server="localhost"config.port=7474config.directory=""# prefix this path with '/'config.cypher_path="/cypher"config.gremlin_path="/ext/GremlinPlugin/graphdb/execute_script"config.log_file="neography.log"config.log_enabled=falseconfig.slow_log_threshold=0# time in ms for query loggingconfig.max_threads=20config.authentication=nil# 'basic' or 'digest'config.username=nilconfig.password=nilconfig.parser=MultiJsonParserconfig.http_send_timeout=1200config.http_receive_timeout=1200config.persistent=trueend

Then initialize aRest instance:

@neo=Neography::Rest.new@neo=Neography::Rest.new({:authentication=>'basic',:username=>"neo4j",:password=>"swordfish"})@neo=Neography::Rest.new("http://neo4j:swordfish@localhost:7474")

For overriding these default and other initialization methods, see theconfiguration and initialization page in the Wiki.

REST API

Neography supports the creation and retrieval of nodes and relationships through the Neo4j REST interface.It supports indexes, Gremlin scripts, Cypher queries and batch operations.

Some of this functionality is shown here, but all of it is explained in the following Wiki pages:

2.0 Only features:

1.8+ features:

Some example usage:

# Node creation:node1=@neo.create_node("age"=>31,"name"=>"Max")node2=@neo.create_node("age"=>33,"name"=>"Roel")# Node properties:@neo.set_node_properties(node1,{"weight"=>200})# Relationships between nodes:@neo.create_relationship("coding_buddies",node1,node2)# Get node relationships:@neo.get_node_relationships(node2,"in","coding_buddies")# Use indexes:@neo.add_node_to_index("people","name","max",node1)@neo.get_node_index("people","name","max")# Batches:@neo.batch[:create_node,{"name"=>"Max"}],[:create_node,{"name"=>"Marc"}]# Cypher queries:@neo.execute_query("start n=node(0) return n")

You can also use thecypher gem instead of writing cypher as text.

node(1).outgoing(rel(:friends).where{|r| r[:since] == 1994})

would become:

START me=node(1) MATCH (me)-[friend_rel:`friends`]->(friends) WHERE (friend_rel.since = 1994) RETURN friends

This is just a small sample of the full API, see theWiki documentation for the full API.

Neography raises REST API errors as Ruby errors, see the wiki page abouterrors.(Note: older versions of Neography did not raise any errors!)

Phase 2

Trying to mimic theNeo4j.rb API.

Now we are returning full objects. The properties of the node or relationship can be accessed directly (node.name).The Neo4j ID is available by usingnode.neo_id.

Some of this functionality is shown here, but all of it is explained in the following Wiki pages:

# create two nodes:n1=Neography::Node.create("age"=>31,"name"=>"Max")n2=Neography::Node.create("age"=>33,"name"=>"Roel")n1.exist?# => true# get and change some properties:n1[:age]# => 31n1.name# => "Max"n1[:age]=32# change propertyn1.weight=190# new propertyn1.age=nil# remove property# add a relationship between nodes:new_rel=Neography::Relationship.create(:coding_buddies,n1,n2)# remove a relationship:new_rel.del# add a relationship on nodes:n1.outgoing(:coding_buddies) <<n2# more advanced relationship traversal:n1.outgoing(:friends)# Get nodes related by outgoing friends relationshipn1.outgoing(:friends).depth(2).include_start_node# Get n1 and nodes related by friends and friends of friendsn1.rel?(:outgoing,:friends)# Has outgoing friends relationshipn1.rels(:friends,:work).outgoing# Get outgoing friends and work relationshipsn1.all_paths_to(n2).incoming(:friends).depth(4)# Gets all paths of a specified typen1.shortest_path_to(n2).incoming(:friends).depth(4).nodes# Gets just nodes in path

This is just a small sample of the full API, see theWiki documentation for the full API.

More

Examples

Someexample code.

Testing

Sometips about testing.

Related Neo4j projects

Complement to Neography are the:

An alternative to Neography isArchitect4r by Maximilian Schulz

Neography in the Wild

Getting started with Neography

Contributing

Please create anew issue if you run into any bugs.

Contribute patches viapull requests.

Help

If you are just starting out, or need help send me an e-mail atmaxdemarzi@gmail.com.

Check you my blog athttp://maxdemarzi.com where I have more Neography examples.

Licenses


[8]ページ先頭

©2009-2025 Movatter.jp