viernes, abril 19, 2024

Calcular la distancia entre dos puntos por latitud y longitud con una función en SQL Server

Calcular la distancia en metros o kilómetros entre dos puntos es muy sencilla. Aquí expongo una función en SQL Server, que retorna la distancia lineal entre dos localidades, solamente se le envía la latitud y longitud de los dos lugares y el tipo de resultado que deseamos, metros (M) o kilómetros (K).

CREATE FUNCTION dn_fn_CalculaDistancia 
(
@latitud1 float,
@longitud1 float,
@latitud2 float,
@longitud2 float,
@unidad_metrica char(1)
)
RETURNS float
AS
BEGIN

	--Unidad Metrica: K=kilometros  M=metros 
	DECLARE @distancia float
	
	--Radio de la tierra según WGS84
	DECLARE @radius float
	SET @radius = 6378.137 

	DECLARE @deg2radMultiplier float 
	SET @deg2radMultiplier = PI() / 180
	
	SET @latitud1 = @latitud1 * @deg2radMultiplier
	SET @longitud1 = @longitud1 * @deg2radMultiplier
	SET @latitud2 = @latitud2 * @deg2radMultiplier
	SET @longitud2 = @longitud2 * @deg2radMultiplier
		
	DECLARE @dlongitud float
	SET @dlongitud = @longitud2 - @longitud1
		
	SET @distancia = ACOS(SIN(@latitud1) * SIN(@latitud2) + COS(@latitud1) *
					 COS(@latitud2) * COS(@dlongitud)) * @radius
	
	IF @unidad_metrica = 'M'  
	   SET @distancia = @distancia * 1000
		
	RETURN @distancia

END
  • Calcular distancia entre coordenadas sql
  • Distancia latitud longitud sql
  • Calcular distancia entre dos puntos
  • Calcular distancia entre dos puntos de ubicación
  • Cómo calcular la distancia entre dos coordenadas GPS
  • Distancia entre dos puntos geográficos
  • Geolocalización en SQL Server
  • Distancia entre dos puntos (dados por longitud y latitud)

Roy Rojas
Roy Rojashttp://www.dotnetcr.com
Con más de 20 años de experiencia en programación, experto en lenguajes .NET, VB, C#, ASP.NET, Xamarin, XCode, DBA en SQL Server. Creador de dotnetcr.com, sitio web para programadores en español. royrojas.com | dotnetcr.com | GitHub
Roy Rojas
Roy Rojashttp://www.dotnetcr.com
Con más de 20 años de experiencia en programación, experto en lenguajes .NET, VB, C#, ASP.NET, Xamarin, XCode, DBA en SQL Server. Creador de dotnetcr.com, sitio web para programadores en español. royrojas.com | dotnetcr.com | GitHub