http://www.sql-server-helper.com/sql-server-2008/convert-latitude-longitude-to-geography-point.aspx
- 方法1、STPointFromTextを使用
ALTER TABLE [dbo].[Landmark]
ADD [GeoLocation] GEOGRAPHY
GO
UPDATE [dbo].[Landmark]
SET [GeoLocation] = geography::STPointFromText('POINT(' + CAST([Longitude] AS VARCHAR(20)) + ' ' + CAST([Latitude] AS VARCHAR(20)) + ')', 4326)
GO
ここは、経度Latitudeより緯度Longitudeが先に来ている。
- 方法2、STGeomFromTextを使用
UPDATE [dbo].[Landmark]
SET [GeoLocation] = geography::STGeomFromText('POINT(' + CAST([Longitude] AS VARCHAR(20)) + ' ' + CAST([Latitude] AS VARCHAR(20)) + ')', 4326)
GO
STGeomFromText は、POINT以外 POLYGON, LINESTRING, MULTIPOINT, MULTIPOLYGON, MULTILINESTRING and GEOMETRYCOLLECTIONもサポートしている。
- 方法3、geography::Pointを使用
UPDATE [dbo].[Landmark]
SET [GeoLocation] = geography::Point([Latitude], [Longitude], 4326)
GO
ここは、経度Latitudeが先で、一番使いやすいと思う。
- 方法4、geography::Parseを使用
UPDATE [dbo].[Landmark]
SET [GeoLocation] = geography::Parse('POINT(' + CAST([Longitude] AS VARCHAR(20)) + ' ' +
CAST([Latitude] AS VARCHAR(20)) + ')')
GO
geography::STGeomFromText と唯一の違いは、spatial reference ID (SRID) 4326の指定は不要。
0 件のコメント:
コメントを投稿