sql >> Databasteknik >  >> NoSQL >> MongoDB

Hur man får avstånd - MongoDB Template Near-funktion

Du kan göra det med geoNear-aggregation . I spring-data-mongodb GeoNearOperation representerar denna aggregering.

Utöka eller skapa ärv Place klass med fält där du vill ha avståndsinformation (exempel med arv):

public class PlaceWithDistance extends Place {
    private double distance;

    public double getDistance() {
        return distance;
    }

    public void setDistance(final double distance) {
        this.distance = distance;
    }
}

Istället för Criteria med Query använda aggregering. Andra argumentet för geoNear är namnet på fältet där avståndet ska ställas in:

final NearQuery nearQuery = NearQuery
    .near(new Point(searchRequest.getLat(), searchRequest.getLng()));
nearQuery.num(5);
nearQuery.spherical(true); // if using 2dsphere index, otherwise delete or set false

// "distance" argument is name of field for distance
final Aggregation a = newAggregation(geoNear(nearQuery, "distance"));

final AggregationResults<PlaceWithDistance> results = 
    mongoTemplate.aggregate(a, Place.class, PlaceWithDistance.class);

// results.forEach(System.out::println);
List<PlaceWithDistance> ls = results.getMappedResults();

Bara för att göra det enklare - tillhörande importer:

import static org.springframework.data.mongodb.core.aggregation.Aggregation.geoNear;
import static org.springframework.data.mongodb.core.aggregation.Aggregation.newAggregation;

import org.springframework.data.mongodb.core.aggregation.Aggregation;
import org.springframework.data.mongodb.core.aggregation.AggregationResults;
import org.springframework.data.mongodb.core.aggregation.GeoNearOperation;
import org.springframework.data.mongodb.core.query.NearQuery;


  1. MongoDB-fråga returnerar tom array

  2. problem med att använda löften med mangust

  3. Hur jämför jag datum från Twitter-data lagrad i MongoDB via PyMongo?

  4. Spring Data Mongo Repository::Gemensam delad metod för alla Repo-frågor