Примечание.
Для доступа к этой странице требуется авторизация. Вы можете попробовать войти или изменить каталоги.
Для доступа к этой странице требуется авторизация. Вы можете попробовать изменить каталоги.
Возвращает объект, представляющий точки, в которых экземпляр geometry пересекается с другим экземпляром geometry.
Синтаксис
.STIntersection ( other_geometry )
Аргументы
- other_geometry
Другой экземпляр geometry, сравниваемый с экземпляром, для которого вызван метод STIntersection(), чтобы определить множество точек их пересечения.
Тип возвращаемых данных
Возвращаемый тип SQL Server: geometry
Возвращаемый тип CLR: SqlGeometry
Замечания
Метод STIntersection() всегда возвращает значение NULL, если идентификаторы пространственной ссылки (SRID) экземпляров geometry не совпадают. Результат может содержать сегменты дуги только в том случае, если они содержатся во входном экземпляре.
Примеры
А.Использование STIntersection() в экземплярах Polygon
В следующем примере с помощью метода STIntersection() вычисляется пересечение двух многоугольников.
DECLARE @g geometry;
DECLARE @h geometry;
SET @g = geometry::STGeomFromText('POLYGON((0 0, 0 2, 2 2, 2 0, 0 0))', 0);
SET @h = geometry::STGeomFromText('POLYGON((1 1, 3 1, 3 3, 1 3, 1 1))', 0);
SELECT @g.STIntersection(@h).ToString();
Б.Использование STIntersection() в экземпляре CurvePolygon
Следующий пример возвращает экземпляр, содержащий сегмент дуги.
DECLARE @g geometry = 'CURVEPOLYGON (CIRCULARSTRING (0 -4, 4 0, 0 4, -4 0, 0 -4))';
DECLARE @h geometry = 'POLYGON ((1 -1, 5 -1, 5 3, 1 3, 1 -1))';
SELECT @h.STIntersection(@g).ToString();