지정된 반경을 가진 여러 원형 마커가 겹치는 결과에 대해 데이터베이스를 쿼리하는 방법은 무엇입니까?

Linda Hamilton
풀어 주다: 2024-10-31 03:04:31
원래의
541명이 탐색했습니다.

How to Query a Database for Results Overlapping Multiple Circular Markers with Specified Radii?

반경 중첩 내 결과에 대한 데이터베이스 쿼리

문제:

지리적 데이터베이스 데이터의 경우 지정된 반경을 가진 여러 원형 마커와 부분적으로 겹치는 결과를 선택하려고 합니다. 기존 SQL 쿼리는 여러 마커가 겹치는 결과를 정확하게 식별하지 못합니다.

해결책:

정확한 결과를 얻으려면 다음 SQL 문을 사용할 수 있습니다.

<code class="sql">SELECT A.user_id, A.radius_id, A.latitude, A.logitude
FROM UserA AS A, 
     (SELECT user_id, latitude, longitude 
       FROM UserB 
       WHERE user_id = 8) AS B
WHERE (POW((A.latitude-B.latitude)*111.12, 2) + POW((A.longitude - B.longitude)*111.12*cos(A.latitude), 2)) <= 4</code>
로그인 후 복사

설명:

이 쿼리는 원의 방정식을 사용하여 UserA의 주어진 지점이 원의 반경(위도 및 UserB의 반경 경도). 다음 단계가 포함됩니다.

  1. 위도와 경도를 킬로미터로 변환합니다. 위도와 경도 차이에 111.12를 곱하여 킬로미터로 변환합니다.
  2. 계산합니다. 원 방정식을 사용한 거리: 수정된 공식 POW((A.latitude-B.latitude)*111.12, 2) POW((A.longitude - B. 경도)*111.12*cos(A.latitude), 2).
  3. 거리와 반경 비교: 계산된 거리가 반경의 제곱보다 작거나 같으면 점은 다음 범위에 속합니다.

이 쿼리를 사용하면 원이 서로 닿아도 여러 개의 원형 마커가 겹치는 결과를 정확하게 식별할 수 있습니다.

위 내용은 지정된 반경을 가진 여러 원형 마커가 겹치는 결과에 대해 데이터베이스를 쿼리하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿