STSymDifference (geography データ型)
任意の geography インスタンスと別の geography インスタンスのいずれかに存在する地点すべてを表すオブジェクトを返します。つまり、両方のインスタンスに存在する地点は除外されます。
構文
.STSymDifference ( other_geography )
引数
- other_geography
STSymDistance() を呼び出したインスタンスの対象となる、別の geography インスタンスです。
戻り値の型
SQL Server の戻り値の型 : geography
CLR の戻り値の型 : SqlGeography
説明
2 つの geography インスタンスの SRID (spatial reference ID) が一致しない場合、このメソッドは常に NULL を返します。
SQL Server では、半球より大きい空間インスタンスをサポートしています。 SQL Server では、サーバー上で使用可能な結果セットが FullGlobe インスタンスに拡張されています。
結果に円弧が含まれるのは、入力インスタンスに円弧が含まれる場合のみです。
使用例
A. 2 つの多角形の対称差を計算する
STSymDifference() を使用して 2 つの Polygon インスタンスの対称差を計算する例を次に示します。
DECLARE @g geography;
DECLARE @h geography;
SET @g = geography::STGeomFromText('POLYGON((-122.358 47.653, -122.348 47.649, -122.348 47.658, -122.358 47.658, -122.358 47.653))', 4326);
SET @h = geography::STGeomFromText('POLYGON((-122.351 47.656, -122.341 47.656, -122.341 47.661, -122.351 47.661, -122.351 47.656))', 4326);
SELECT @g.STSymDifference(@h).ToString();
B. FullGlobe を使用して、対称差を計算する
FullGlobe を使用して、Polygon の対称差を比較する例を次に示します。
DECLARE @g geography = 'POLYGON((-122.358 47.653, -122.348 47.649, -122.348 47.658, -122.358 47.658, -122.358 47.653))';
SELECT @g.STSymDifference('FULLGLOBE').ToString();