집 >데이터 베이스 >MySQL 튜토리얼 >SQL Server는 어떻게 두 위도/경도 지점 사이의 거리를 정확하게 계산할 수 있습니까?
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!