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