Sqlserver
 sql >> Baza danych >  >> RDS >> Sqlserver

SQL Server generujący losową geografię przestrzenną wokół punktu?

Znalazłem odpowiedź z tego posta https://gis.stackexchange.com/a/25883/ 37373

Zaadaptowałem odpowiedź do kodu SQL Server.

DECLARE @geo as GEOGRAPHY,@newgeo as GEOGRAPHY
SET @geo = (SELECT ZipGeo FROM Location.ZipCodes WHERE ZipCode='90210')

DECLARE @r float,@t float, @w float, @x float, @y float, @u float, @v float;

SET @u=RAND();
SET @v=RAND();

--8046m = ~ 5 miles
SET @r= 8046/(111300*1.0);
SET @w = @r * sqrt(@u);
SET @t = 2 * PI() * @v;
SET @x = @w * cos(@t);
SET @y = @w * sin(@t);
SET @x = @x / cos(@geo.Lat);

SET @newgeo = geography::STPointFromText('POINT('+CAST(@[email protected] AS VARCHAR(MAX))+' '+CAST(@[email protected] AS VARCHAR(MAX))+')',4326)
--Convert the distance back to miles to validate
SELECT @geo.STDistance(@newgeo)/1609.34



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Jaki jest najlepszy sposób programowego testowania połączenia z programem SQL Server?

  2. Zapytanie SQL uzyskać liczbę pozycji do raportu na dzień miesiąca?

  3. SQL Server COALESCE() Objaśnienie

  4. SQL Server 2008 IDENTITY_INSERT jest włączony błąd podczas wstawiania

  5. Jak znaleźć listę procedur składowanych, które mają wpływ na konkretną kolumnę?