Menu Docs
Página inicial do Docs
/ / /
Driver Ruby MongoDB
/

Atlas Searchgeoespacial

O MongoDB oferece vários índices e mecanismos de query para lidar com informações geoespaciais. Esta seção demonstra como criar e utilizaríndices geoespaciais do com o driver Ruby.

Os exemplos nesta página utilizam uma collection de amostra denominada restaurants no banco de dados do test . Um conjunto de dados de amostra está disponível para download.

O seguinte é um documento na collection restaurants :

{
"address": {
"building": "1007",
"coord": [ -73.856077, 40.848447 ],
"street": "Morris Park Ave",
"zipcode": "10462"
},
"borough": "Bronx",
"cuisine": "Bakery",
"grades": [
{ "date": { "$date": 1393804800000 }, "grade": "A", "score": 2 },
{ "date": { "$date": 1299715200000 }, "grade": "B", "score": 14 }
],
"name": "Morris Park Bake Shop",
"restaurant_id": "30075445"
}

O seguinte exemplo cria um índice 2dsphere no campo address.coord:

client = Mongo::Client.new([ '127.0.0.1:27017' ], :database => 'test' )
client[:restaurants].indexes.create_one( { 'address.coord' => '2dsphere' })

Depois que o índice é criado, você pode usar vários operadores para fazer query em relação a ele, incluindo os operadores $near, $geoWithin e $geoIntersects . O exemplo a seguir usa o operador $near para encontrar todos os restaurantes em um raio 500 metros das coordenadas fornecidas.

client = Mongo::Client.new('mongodb://127.0.0.1:27017/test')
collection = client[:restaurants]
collection.find(
{ 'address.coord' =>
{ "$near" =>
{ "$geometry" =>
{ "type" => "Point", "coordinates" => [ -73.96, 40.78 ] },
"$maxDistance" => 500
}
}
}
).each do |doc|
#=> Yields a BSON::Document.
end

Para encontrar todos os documentos com um local dentro do território de um determinado polígono, use o operador $geoWithin :

client = Mongo::Client.new('mongodb://127.0.0.1:27017/test')
collection = client[:restaurants]
collection.find(
{ "address.coord" =>
{ "$geoWithin" =>
{ "$geometry" =>
{ "type" => "Polygon" ,
"coordinates" => [ [ [ -73, 40 ], [ -74, 41 ], [ -72, 39 ], [ -73, 40 ] ] ]
}
}
}
}
).each do |doc|
#=> Yields a BSON::Document.
end

Voltar

Pesquisa de texto