2014-09-17 2 views
0

위치 정보 기능을 사용하여 앱을 제작 중입니다. 현재 데이터를 저장하고 쿼리하는 가장 좋은 방법은 무엇입니까? 내 일반적인 사용 사례입니다.데이터에 거리 제한이있는 공간 쿼리

사람 A는 지리적 위치가있는 이미지를 추가합니다. 지리적 위치 데이터 외에도 1 마일 이내에있는 사용자에게만 이미지가 표시된다는 플래그를 추가했습니다.

지금 내 질문은이 정보를 저장하는 가장 좋은 방법은 다른 사람이 현재 위치 주변의 모든 이미지를 볼 수 있도록 저장되는 이미지의 제한을 존중하면서 볼 수 있도록하는 것입니다. 1 마일 만 볼 수 있고 2 마일 만 볼 수 있습니다.

+0

solr로 제한되었거나 다른 해결책이 가능합니까? –

+0

다른 데이터 저장소를 사용해 볼 때 열려 있습니다. – sevenFLiP

답변

0

Solr은 최근 Java Topology Suite 라이브러리를 통해 상당히 향상 된 지리 정보 검색 기능을 제공합니다. Solr documentation는 q는 검색의 비 지리 부분이 될 것입니다

&q=*:*&fq={!geofilt sfield=location}&pt=41.38,2.18&d=5 

는 sfield은 당신의 위치 필드, 당신은 어떤 시점, 예를 들면의 거리 d와 아무것도 찾을 수있는 거리 필터를 사용하는 예제가 있습니다 , pt는 포인트입니다 (lat/lon에 있어야하며 위의 예에서는 Barcelona 임). d는 거리 필드입니다. d 매개 변수의 이미지를 얼마나 멀리 볼 수 있는지 속성을 사용할 수 있습니다.

더 가까운 물건을 강조 표시하려면 거리별로 정렬 할 수있는 측지 기능이 있습니다.

사용할 수있는 또 다른 방법은 공간 데이터베이스를 사용하고 위치 데이터를 위치 필드로 저장하는 것입니다. Postgres/Postgis의 예제로 http://postgis.net/docs/ST_DWithin.html 함수를 사용할 수 있습니다.이 함수를 사용하면 어느 정도 거리 내의 모든 것을 검색 할 수 있습니다. Postgres/GIS는 spatial indexing에 R-tree 인덱스를 사용하므로 매우 빠르고 효율적으로 검색 할 수 있습니다. 또한 속성 부분에 대해 전체 텍스트 검색 기능이 뛰어납니다.

select * from images where ST_DWithin(point, st_setsrid(st_makepoint(2.1, 41.38), 4326), 5); 

오라클과 SQL Server (그리고 그보다 다소 적지 만 MySQL의 경우)와 비슷한 기능을 제공 할 수 있습니다. 이 접근법은 Solr 접근 방식보다 더 복잡해 보일 수 있습니다.이 지점의 거리 d 이내에서이 속성과 일치하는 모든 이미지를 lat/lon으로 검색하는 경우 SOLR은 원하는 것을 확실히 수행하지만 원하는 경우 향후 고급 공간 기능을 고려하고 다른 데이터베이스 기능을 활용하려면 공간 데이터베이스 접근 방식을 고려해야합니다.

+0

John에게 답변 해 주셔서 감사합니다. 나는 solr을 사용하는 것에 익숙하다. 그리고 그렇게하는 것이 최선의 방법이라면 나는 생각하고있다. 내 검색은 공간 검색 + 속성 검색입니다. 나는 postgres/postgis도 살펴 봤지만 벤치 마크를 수행 할 데이터가별로 없기 때문에 어떤 벤치 마크를 더 빨리, solr 또는 postgresql/postgis로 수행하지 않았다. – sevenFLiP

+0

solr 추정에 대한 사과. 필자의 경험으로 볼 때, tsearch와 다양한 contrib 패키지를 통해 Postgres에서 텍스트를 검색하는 것은 매우 강력하지만, 상당히 많은 양의 튜닝이 필요하지만, Solr (Lucene)은 다소간의 효과를 발휘합니다. Postgres와 Solr은 물론 Solst에 JTS를 포함 시키더라도 Postgis의 공간 기능과 데이터 저장소의 관점에서 볼 때 매우 다른 짐승입니다. 궁극적으로, 예상 한 유스 케이스 테스트만으로 결정할 수 있습니다. 테스트는 사용자가 말한 것처럼 문제가 될 수 있습니다. –