>  기사  >  데이터 베이스  >  대규모 비즈니스 데이터베이스에 대한 위치 기반 검색 쿼리를 어떻게 최적화할 수 있습니까?

대규모 비즈니스 데이터베이스에 대한 위치 기반 검색 쿼리를 어떻게 최적화할 수 있습니까?

Patricia Arquette
Patricia Arquette원래의
2024-11-08 09:02:01777검색

How Can I Optimize Location-Based Search Queries for Large Business Databases?

위치 기반 검색 최적화

주변 위치를 효율적으로 찾는 것은 지도 및 내비게이션과 같은 애플리케이션에 매우 중요합니다. Haversine 공식은 구 위의 두 점 사이의 거리를 계산하는 데 널리 사용되는 방법입니다. 이 공식을 SQL에서 직접 구현하여 위치 기반 검색 쿼리를 최적화할 수 있습니다.

귀하의 경우, 5,000개 이상의 업체에 대한 거리 계산 성능이 걱정됩니다. Haversine 수식과 함께 다음 MySQL 쿼리를 사용해 보세요.

SELECT id, (3959 * acos(cos(radians(37)) * cos(radians(lat))
* cos(radians(lng) - radians(-122)) + sin(radians(37))
* sin(radians(lat)))) AS distance
FROM markers
HAVING distance < 25
ORDER BY distance LIMIT 0, 20;

이 쿼리에서 "37"과 "-122"를 사용자 위치의 위도와 경도로 바꿉니다. 데이터베이스 내에서 거리를 계산하면 모든 업체를 검색하고 PHP로 거리 계산을 수행할 필요가 없습니다.

이 최적화된 접근 방식을 사용하면 근처 위치 검색 속도를 크게 향상시켜 적합하게 만들 수 있습니다. 대규모 데이터베이스를 처리하기 위한 것입니다. 최적의 성능을 위해서는 거리 계산과 관련된 열을 인덱싱하는 것이 중요합니다.

위 내용은 대규모 비즈니스 데이터베이스에 대한 위치 기반 검색 쿼리를 어떻게 최적화할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.