SQL Server地理查询可以工作,但几何查询不起作用 - 不同的表,类似的模式

时间:2015-06-03 20:50:43

标签: sql sql-server sqlgeography sqlgeometry

我正在尝试使用Geometry查询。类似的Geography查询工作正常但我必须使用使用Geometry类型的表。尽管Geography版本按预期返回了大量记录,但我无法获得Geometry版本以返回任何记录。两个表都具有完全相同的纬度和经度记录。

此地理位置查询可以正常运行:

DECLARE @home GEOGRAPHY
SET @home = GEOGRAPHY::STPointFromText('POINT(-0.7799193 51.3083162 )', 4326);

SELECT OutwardCode, InwardCode, Latitude, Longitude
FROM dbo.PostCodeData
WHERE GeoLocation.STDistance(@home) <= (5 * 1609) -- 1609 = approx metres in 1 mile

表架构是:

+-------------+--------------+
|    Field    |     Type     |
+-------------+--------------+
| OutwardCode | Varchar(4)   |
| InwardCode  | Varchar(3)   |
| Latitude    | Decimal(9,6) |
| Longitude   | Decimal(9,6) |
| GeoLocation | Geography    |
+-------------+--------------+

示例表数据:

+-------------+------------+------------+----------+------------------------------------------------+
| OutwardCode | InwardCode | Longitude  | Latitude |                  GeoLocation                   |
+-------------+------------+------------+----------+------------------------------------------------+
| GU14        | 9HL        | -0.7803759 | 51.30818 | 0xE6100000010C01A4367172A7494027C522E1D6F8E8BF |
+-------------+------------+------------+----------+------------------------------------------------+

此Geometry查询不返回任何记录(我在数据库中具有完全相同的纬度和经度记录,但将Geometry作为街道的中心点,Postcode是OutwardCode和InwardCode的连接版本):

DECLARE @home GEOMETRY
SET @home = GEOMETRY::STPointFromText('POINT(51.3083162 -0.7799193)', 0);

SELECT Postcode, Latitude, Longitude
FROM dbo.OS_Locator
WHERE Centre.STDistance(@home) <= (5 * 1609) -- 1609 = approx metres in 1 mile

表架构是:

+-----------+--------------+
|   Field   |     Type     |
+-----------+--------------+
| Postcode  | nvarchar(10) |
| Latitude  | Decimal(9,6) |
| Longitude | Decimal(9,6) |
| Centre    | Geometry     |
+-----------+--------------+

示例表数据:

+----------+-----------+-----------+------------------------------------------------+
| Postcode | Latitude  | Longitude |                     Centre                     |
+----------+-----------+-----------+------------------------------------------------+
| GU14 9HL | 51.308304 | -0.779928 | 0x346C0000010C00000000549C1D410000000018330341 |
+----------+-----------+-----------+------------------------------------------------+

我哪里错了?

1 个答案:

答案 0 :(得分:1)

有一个原因是有两种不同的地理空间类型。当您的坐标表示地球上的点的纬度和经度(一个在其坐标系中具有奇点的三维物体)时,地理就是这样。几何是指你的点代表任意X&amp; Y位于无限平面上。你不能只说“我将采取51.3度,并使其成为X坐标”,并让一切正常。正如我的高中物理老师总是说“单位很重要”。