0
votes

I've got an existing project for which I want to build a spatial index.

I can created a spatial index for a pre-existing Neo4j database managed by spring-data-neo4j on the existing database by adding @Index to the domain class:

@NodeEntity
class Junction {
    @GraphId Long id;
    @Indexed(indexType = IndexType.POINT, indexName = "junctionLocations") Point wkt;
}

I've populated the wkt's for all the existing nodes in the graphdb, but I can't work out how to add the existing nodes to the new spatial index. It's not possible for me to rebuild the graph from scratch because it already has many layers connected to these existing nodes through pre-existing relationships.

I've been through the unit tests for spatial and for SDN, but none of them document how to add an existing node to a new index. I also can't work out in the code where nodes are added to the index defined by SDN.

Can anyone help please?

2
Hi Joe !! Did you get any solution? Currently i'm stucking in situation like this but somehow not able to solve it. Here is my questionlink .Any suggestion please.niraj darji
Yes I did. In my case it was just a simple matter of loading each node and saving it again to get it added to the index.Dr Joe

2 Answers

1
votes

I'm not a Spring kinda guy, but here are some answers to the general question that may be of help.

0
votes

I forgot that this question hadn't been answered.

The answer was simple. Every time a node is saved in Spring-data-neo4j, it is added to any defined indexes at that point. So the solution was just to iterate over all the pre-existing nodes and re-save them.

Problem solved.