精华 在neo4j 4.x中进行空间查询
发布于 23 天前 作者 codingmiao 157 次浏览 来自 分享

空间查询有着广泛的应用场景,例如,我们打开手机地图查看附近有哪些美食,或者网约车时为用户分配最近的车辆,一切基于地理坐标的查询,都需要空间查询的帮助。

neo4j-contrib有一个著名的空间插件 https://github.com/neo4j-contrib/spatial就能实现上诉功能。

然鹅,,Neo4j Spatial已经有16个月未更新,Neo4j 4.0的发布,大量的api重写导致Neo4j Spatial已不可用, 所以我抽取了Neo4j Spatial中的空间索引部分并适配至Neo4j 4.0,撸了一个4.x版本能用的空间索引出来,希望对大家有帮助~~~~~~~

项目地址 https://github.com/codingmiao/neo4j-rtree

使用示例:

新建空间索引 RTreeIndex rTreeIndex = RTreeIndexManager.createIndex(db, “index1”, “geometry”, 64);

为node加入空间索引: Transaction tx = db.beginTx(); Node node = tx.createNode(testLabel);//新建节点 Point geo = wkbReader.read(“POINT(10 20)”); byte[] wkb = wkbWriter.write(geo);//转为wkb node.setProperty(“geometry”, wkb);//设置空间字段值,必须为wkb格式 rTreeIndex.add(node,tx);//加入索引

//输入一个矩形范围,查询矩形覆盖的节点 double[] bbox = new double[]{3, 1, 8, 9}; try (Transaction tx = db.beginTx()) { RtreeQuery.queryByBbox(tx, rTreeIndex, bbox, (node, geometry) -> { System.out.println(node.getProperty(“xxxx”)); }); }

//输入一个geometry,查询geometry覆盖的节点 Geometry inputGeo = new WKTReader().read(“POLYGON ((11 24, 22 28, 29 15, 11 24))”); try (Transaction tx = db.beginTx()) { RtreeQuery.queryByGeometryIntersects(tx, rTreeIndex, inputGeo, (node, geometry) -> { System.out.println(node.getProperty(“xxxx”)); }); }

2 回复

那个控件索引插件很不靠谱

@pangguoming 是的,毕竟是用爱发电的项目O(∩_∩)O。不过它提供了一个用图库来表达rtree的思路,有需要都可以基于它扩展

回到顶部