>데이터 베이스 >MySQL 튜토리얼 >SQL Server는 어떻게 두 위도/경도 지점 사이의 거리를 정확하게 계산할 수 있습니까?

SQL Server는 어떻게 두 위도/경도 지점 사이의 거리를 정확하게 계산할 수 있습니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2025-01-12 13:08:45865검색

How Can SQL Server Accurately Calculate the Distance Between Two Latitude/Longitude Points?

SQL Server에서 지리적 지점 간의 거리를 정확하게 계산

지도 좌표 간의 정확한 거리 계산이 중요합니다. 일부 수식은 근사치를 제공하지만 SQL Server의 기본 제공 기능은 뛰어난 정밀도를 제공합니다.

SQL Server의 geography 데이터 유형 활용(SQL Server 2008 이상)

geography 데이터 유형(SQL Server 2008 이상 버전에서 사용 가능)은 거리 계산을 위한 강력한 솔루션을 제공합니다. 방법은 다음과 같습니다.

<code class="language-sql">DECLARE @source geography = 'POINT(0 51.5)'
DECLARE @target geography = 'POINT(-3 56)'

SELECT @source.STDistance(@target)</code>

이 쿼리는 거리를 미터 단위로 반환합니다.

기존 데이터와 geography 유형 통합

설정된 데이터베이스 스키마로 작업하는 경우 geography 유형을 원활하게 통합할 수 있습니다. Point 메소드를 사용하면 다음과 같은 작업이 가능합니다.

<code class="language-sql">DECLARE @orig_lat DECIMAL(12, 9)
DECLARE @orig_lng DECIMAL(12, 9)
SET @orig_lat=53.381538; SET @orig_lng=-1.463526;

DECLARE @orig geography = geography::Point(@orig_lat, @orig_lng, 4326);

SELECT *,
    @orig.STDistance(geography::Point(dest.Latitude, dest.Longitude, 4326)) AS distance
FROM #orig dest;</code>

이 예에서는 거리 계산을 위해 geography 데이터 유형의 정확성을 활용하면서 기존 데이터 구조를 유지합니다.

위 내용은 SQL Server는 어떻게 두 위도/경도 지점 사이의 거리를 정확하게 계산할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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