首页
/ Neography 技术文档

Neography 技术文档

2024-12-17 17:33:59作者:宗隆裙

1. 安装指南

使用 Gemfile 安装

将 Neography 添加到你的 Gemfile 中:

gem 'neography'

然后运行 Bundler:

$ bundle

手动安装

或者手动安装 Neography:

$ gem install 'neography'

在 Ruby 代码中引入宝石:

require 'rubygems'
require 'neography'

有关依赖项的更多信息,请查阅依赖项文档

2. 项目使用说明

Neography 是一个轻量级的 Ruby 包装器,用于 Neo4j Rest API。以下是配置和初始化 Neography 的步骤:

Neography.configure do |config|
  config.protocol             = "http"
  config.server               = "localhost"
  config.port                 = 7474
  config.directory            = ""  # 前缀路径与 '/'
  config.cypher_path          = "/cypher"
  config.gremlin_path         = "/ext/GremlinPlugin/graphdb/execute_script"
  config.log_file             = "neography.log"
  config.log_enabled          = false
  config.slow_log_threshold   = 0    # 查询日志的毫秒时间
  config.max_threads          = 20
  config.authentication       = nil  # 'basic' 或 'digest'
  config.username             = nil
  config.password             = nil
  config.parser               = MultiJsonParser
  config.http_send_timeout    = 1200
  config.http_receive_timeout = 1200
  config.persistent           = true
end

初始化 Rest 实例:

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

有关更多配置和初始化方法,请参阅配置和初始化文档

3. 项目API使用文档

Neography 支持通过 Neo4j REST 接口创建和检索节点和关系。它支持索引、Gremlin 脚本、Cypher 查询和批处理操作。

以下是部分功能示例:

节点创建

node1 = @neo.create_node("age" => 31, "name" => "Max")
node2 = @neo.create_node("age" => 33, "name" => "Roel")

节点属性

@neo.set_node_properties(node1, {"weight" => 200})

节点关系

@neo.create_relationship("coding_buddies", node1, node2)

获取节点关系

@neo.get_node_relationships(node2, "in", "coding_buddies")

使用索引

@neo.add_node_to_index("people", "name", "max", node1)
@neo.get_node_index("people", "name", "max")

批处理

@neo.batch [:create_node, {"name" => "Max"}],
           [:create_node, {"name" => "Marc"}]

Cypher 查询

@neo.execute_query("start n=node(0) return n")

更多 API 信息,请参考Wiki 文档

4. 项目安装方式

请按照以上“安装指南”部分中所述的步骤进行安装。您可以使用 Gemfile 进行自动安装,也可以手动安装宝石并引入到您的 Ruby 代码中。

热门项目推荐
相关项目推荐

项目优选

收起
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
46
34
PDFMathTranslatePDFMathTranslate
PDF scientific paper translation with preserved formats - 基于 AI 完整保留排版的 PDF 文档全文双语翻译,支持 Google/DeepL/Ollama/OpenAI 等服务,提供 CLI/GUI/Docker
Python
25
2
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
171
39
RuoYi-VueRuoYi-Vue
🎉 基于SpringBoot,Spring Security,JWT,Vue & Element 的前后端分离权限管理系统,同时提供了 Vue3 的版本
Java
164
33
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
248
63
RuoYi-Cloud-Vue3RuoYi-Cloud-Vue3
🎉 基于Spring Boot、Spring Cloud & Alibaba、Vue3 & Vite、Element Plus的分布式前后端分离微服务架构权限管理系统
Vue
21
17
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
892
0
GitCode光引计划有奖征文大赛GitCode光引计划有奖征文大赛
GitCode光引计划有奖征文大赛
16
1
RuoYi-CloudRuoYi-Cloud
🎉 基于Spring Boot、Spring Cloud & Alibaba的分布式微服务架构权限管理系统,同时提供了 Vue3 的版本
Java
25
10
advanced-javaadvanced-java
Advanced-Java是一个Java进阶教程,适合用于学习Java高级特性和编程技巧。特点:内容深入、实例丰富、适合进阶学习。
JavaScript
389
102