- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是 Neo4J 的新手,我正在尝试为基于时空的高可用性查询构建概念证明。
我有一个设置,其中包含 2 个独立的 Neo4J Enterprise 服务器和一个使用嵌入式 HA Neo4J 服务器运行的 Java 应用程序。
一切都易于设置,基本查询也易于设置且高效。另外执行从 Neo4J 派生的查询 SpatialRepository按预期工作。
我很难理解的是如何使用 SDN 结合任何其他 where 子句进行空间查询。作为一个简单的例子,我如何编写查找名为 X 的用户在纬度/经度 Y 英里范围内的所有位置。因为 SpatialRepository 不是常规 Spring Repository 类树的一部分,所以我不相信我可以使用任何命名约定,我的意图是执行空间查询然后过滤结果吗?
我已经追踪到 LegacyIndexSearcher(它的名字让我感到害怕!)的代码,但看不到任何扩展搜索的机制。我也看过 IndexProviderTest在 GitHub 上,它可以提供一种手动机制来对索引执行查询,但我认为可能有两个索引在起作用。
如果我了解如何构建可以在 @Query 注释中使用的 Cypher 查询,这可能会有所帮助。虽然我已经能够使用控制台执行简单的 REST 查询:
:POST /db/data/ext/SpatialPlugin/graphdb/findGeometriesWithinDistance { "layer":"location", "pointX":0.0, "pointY":51.526256, "distanceInKm":100 }
这不起作用:
start n=node:location('withinDistance:[51.526256,0.0,100.0]') return n;
错误是:
Index `location` does not exist Neo.ClientError.Schema.NoSuchIndex
索引是(可能天真地)使用 Spring 创建的:
@Indexed(indexType = IndexType.POINT, indexName = "location") String wkt;
如果我运行 index --indexes
在控制台中,我可以看到没有名为 location 的索引,但是有一个名为 location__neo4j-spatial__LayerNodeIndex__internal__spatialNodeLookup__
的索引。 .
我需要手动创建索引吗?如果是这样,有人可以指出文档的方向,我会继续进行。
假设只是无知让我无法运行简单的 Cypher 查询,那么它是否就像向查询添加常规 Cypher WHERE 子句以执行基于空间和属性的查询的组合一样简单?
添加了更多索引详细信息
运行了:GET /db/data/index/node/
从控制台我可以看到两个可能有用的索引(其他索引已删除):
{ "location__neo4j-spatial__LayerNodeIndex__internal__spatialNodeLookup__": { "template": "/db/data/index/node/location__neo4j-spatial__LayerNodeIndex__internal__spatialNodeLookup__/{key}/{value}", "provider": "lucene", "type": "exact" }, "GeoTemporalThing": { "template": "/db/data/index/node/GeoTemporalThing/{key}/{value}", "provider": "lucene", "type": "exact" }}
所以也许这应该是我正在尝试的查询的正确格式:
start n=node:GeoTemporalThing('withinDistance:[51.526256,0.0,100.0]') return n;
但这给了我这个错误(我现在正在谷歌搜索)
org.apache.lucene.queryParser.ParseException: Cannot parse 'withinDistance:[51.526256,0.0,100.0]': Encountered " "]" "] "" at line 1, column 35.Was expecting one of: "TO" ... ... ...
更新
确定我的索引不存在并且我应该使用 REST 接口(interface)创建一个索引,该索引的名称是我希望 SDN 创建的,如下所示:
:POST /db/data/index/node{ "name" : "location", "config" : { "provider" : "spatial", "geometry_type" : "point", "wkt" : "wkt" }}
而且,现在一切似乎都运行良好。所以,我的问题是,我是否必须手动创建该索引?如果我查看 org.springframework.data.neo4j.support.index.IndexType 中的代码,它看起来好像应该使用我上面使用的设置,但它只创建了长命名的 Lucene 索引:
public enum IndexType{ @Deprecated SIMPLE { public Map getConfig() { return LuceneIndexImplementation.EXACT_CONFIG; } }, LABEL { public Map getConfig() { return null; } public boolean isLabelBased() { return true; }}, FULLTEXT { public Map getConfig() { return LuceneIndexImplementation.FULLTEXT_CONFIG; } }, POINT { public Map getConfig() { return MapUtil.stringMap( IndexManager.PROVIDER, "spatial", "geometry_type" , "point","wkt","wkt") ; } } ; public abstract MapgetConfig(); public boolean isLabelBased() { return false; }}
我确实清理了系统并且行为是一样的,我是否遗漏了一个步骤?
软件详情:
java :
neo4j 2.0.1
neo4j-ha 2.0.1
neo4j-空间 0.12-neo4j-2.0.1
spring-data-neo4j 3.0.0.RELEASE
独立服务器:
neo4j-enterprise-2.0.1
neo4j-spatial-0.12-neo4j-2.0.1-server-plugin
最佳答案
我不确定这是否是 Spring Data 在设置索引时的错误,但使用 REST 索引手动创建索引是可行的:
:POST /db/data/index/node{ "name" : "location", "config" : { "provider" : "spatial", "geometry_type" : "point", "wkt" : "wkt" }}
我现在可以在 @Query 注释中使用 cypher 以最小的努力执行查询(显然会有更多参数):
@Query(value = "start n=node:location('withinDistance:[51.526256,0.0,100.0]') MATCH user-[wa:WAS_HERE]-n WHERE wa.ts > {ts} return user"Page findByTimeAtLocation(@Param("ts") long ts);
关于Neo4J、SDN 和运行 Cypher 空间查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22200571/
我已经在 OSX 上安装了 Docker 并下载了 neo 镜像。当我运行它时(使用图像主页中的 args),一切似乎都正常,但日志的最后几行表明如下: 00:20:39.662 [main] INF
我的正则表达式在 neos 项目中不能正常工作。DD/MM/YYYY 的正则表达式(仅限 19XX-20XX) var date_regex = /^(0[1-9]|1\d|2\d|3[01])\/(
Neo 4j可以与HDFS / Hadoop集成吗?在处理涉及许多关系且每秒具有大量事务的大型数据集时,通常使用Hadoop来提高Neo 4j的处理能力。 最佳答案 这是一个非常广泛的问题。也许考虑提
我尝试在 NEO 环境中使用 TenantAccessor。TenantAccessor.getCurrentTenant().getTenantId() 生成的 TenantId 作为 GUID 返
我下载了Neoclipse Source并下载了 Neo4J source 。但是 Neo4J 源文件中找不到 Neoclipse 源文件引用的某些类。它们已被弃用吗?我可以获得 Neoclipse
进程文件: neo or neo.exe 进程名称: Price Patrol 进程类别:存在安全风险的进程 英文描述: neo.exe is the execuatble for Pric
load csv with headers from 'file:///C:/Users/user/Desktop/Neo4J' as row Create (:State_Code {state_c
如何在 SAPUI5 应用程序的运行时为 neo-app.json 文件的 routes 部分定义新条目?例如在 Component.js 内部。 例如,我想将以下条目添加到文件中,或者将一些代码添加
我最近将一台计算机变成了 Ubuntu 服务器。我已经按照下面的文章 http://neos.readthedocs.io/en/stable/GettingStarted/Installation.
我正在尝试了解如何使用 NEOS Server for SCIP .我已经阅读了有关 CPLEX LP file format 的教程.但我仍然得不到任何结果。 让我们以该教程中提供的示例为例: Ma
关于这一年Bubble Cup (完)有问题NEO (我无法解决),它要求 给定一个包含 n 个整数元素的数组。我们把它分成几个部分(可能是1个),每个部分都是一个连续的元素。这种情况下的 NEO 值
我的 Rails 应用程序必须使用 Neo4j。所以我开始安装 neo4j 服务器。我按照步骤安装 here在 Linux 上。 但是当我运行的时候 ./bin/neo4j console 它给了 E
我刚从 windows 10 切换到 arch linux我想使用 (Neo)Vim 作为我的代码编辑器我已经完成了自动编译和模糊查找器但我不知道如何在 (Neo)Vim 中调试 任何帮助! 最佳答案
我想问一下,如何使用Spring boot找到Dijkstra。 我目前使用 spring-boot-starter-data-neo4j 库将 Neo4j 与我的 java 类映射。 我现在想使用
我正在尝试创建一个可以从 U2F token (例如 Java 语言的 Yubikey Neo)检索公钥和私钥的应用程序。我尝试在控制台中使用简单的扫描仪从 Yubikey Neo 获取任何内容,但它
我想用摩托罗拉68000汇编器写一个程序,目标平台是Neo Geo(九十年代的游戏机);这个问题很严重,我有一个我想实现的特定项目并且我有编程经验(虽然我现在主要是 Perl/R 编程,但我以前只接触
我使用自定义 Web 服务作为 neo4j 的非托管扩展。 这是 Neo4j 提供的详细信息,我已遵循该详细信息并创建了自己的非托管扩展。 http://neo4j.com/docs/stable/s
Typo3 Neos 是否原生支持元素的响应行为?例如像 css 网格类(col-sm-?? 或 col-md-??)这样的 Bootstrap ,或者我可以使用 Neos 通过 hidden-xs
我是为嵌入式板构建自定义 Linux 操作系统的新手 - 所以请忽略我的无知。 我有一个名为 NanoPi NEO 的开发板,它具有定制的 Debian Linux。现在开发板附带一个 .img 文件
我正在尝试使用脚本在 NEO4j db 中导入 csv 文件: LOAD CSV FROM "file:///dataframe6.txt" AS line RETURN count(*) 但我收到以
我是一名优秀的程序员,十分优秀!