Алексей Паутов - MySQL: руководство профессионала
Geometry базовый класс. Это абстрактный класс. Подклассы Geometry ограничены нуль-, одно- и двумерными геометрическими объектами, которые существуют в двумерном координатном пространстве. Все instantiable классы геометрии определены так, чтобы допустимые образцы класса были закрытой топологии (то есть, все определенные конфигурации включают их границу).
Основной класс Geometry имеет подклассы для Point, Curve, Surface и GeometryCollection:
Point представляет нуль-мерные объекты.
Curve представляет одномерные объекты и имеет подкласс LineString с под-подклассами Line и LinearRing.
Surface разработан для двумерных объектов и имеет подкласс Polygon.
GeometryCollection имеет специальные коллекции для нуль-, одно- и двумерных объектов, известные как MultiPoint, MultiLineString и MultiPolygon для конфигураций моделирования, соответствующих совокупностям Points, LineStrings и Polygons, соответственно. MultiCurve и MultiSurface представляются как абстрактные суперклассы, которые обобщают интерфейсы совокупности, чтобы обработать Curves и Surfaces.
Geometry, Curve, Surface, MultiCurve и MultiSurface определены как non-instantiable классы. Они определяют общий набор методов для их подклассов и включены для расширяемости.
Point, LineString, Polygon, GeometryCollection, MultiPoint, MultiLineString и MultiPolygon instantiable классы.
4.2.2. Класс Geometry
Geometry представляет собой корневой класс иерархии. Это non-instantiable класс, но имеет ряд реквизитов, которые являются общими для всех значении геометрии, созданных любым из подклассов Geometry. Эти реквизиты описаны в следующем списке. Специфические подклассы имеют их собственные специфические реквизиты, описанные позже.
Реквизиты геометрии
Значение геометрии имеет следующие реквизиты:
type. Каждая геометрия принадлежит одному из instantiable классов в иерархии.
SRID или Spatial Reference Identifier (пространственный идентификатор ссылки). Это значение идентифицирует связанную пространственную систему ссылки геометрии, которая описывает координатное пространство, в котором объект геометрии определен. В MySQL значение SRID только целое число, связанное со значением геометрии. Все вычисления выполнены, принимая Евклидову (плоскую) геометрию.
Координата в пространственной системе ссылки, представляемая как числа двойной точности (с восьмью байтами). Все не пустые конфигурации включают по крайней мере одну пару координат (X,Y). Пустые конфигурации не содержат никаких координат.
Координаты связаны со SRID. Например, в различных системах координат расстояние между двумя объектами может отличаться даже, когда объекты имеют те же самые координаты потому, что расстояние на плоской системе координат и расстояния на геоцентрической системе (на поверхности Земли) разные вещи.
Внутренний, граничный и внешний.
Каждая геометрия занимает некоторую позицию. Внешнее, с точки зрения геометрии, это все место, не занятое геометрией. Внутреннее, соответственно, место, занятое геометрией. Граница находится между внутренним и внешним.
MBR (Minimum Bounding Rectangle) или Envelope (минимальный ограничительный прямоугольник, конверт). Это геометрия ограничения, сформированная минимумом и максимумом (X,Y):((MINX MINY, MAXX MINY, MAXX MAXY, MINX MAXY, MINX MINY))
Является ли значение простым или нет. Значения геометрии типов (LineString, MultiPoint, MultiLineString) являются простыми или не простыми. Каждый тип определяет собственные утверждения, будучи простым или не простым.
Закрыто ли значение или нет. Значения геометрии типов (LineString, MultiString) закрыты или не закрыты. Каждый тип определяет собственные утверждения.
Является ли значение пустым или не пустым: геометрия пуста, если не имеет никаких точек. Внешний, внутренний и граница пустой геометрии не определены (то есть они представляются значением NULL). Пустая геометрия определена, чтобы быть всегда простой и имеет область 0.
Размерность. Геометрия может иметь размерность 0, 1 или 2:
0 для геометрии без длины и никакой области.
1 для геометрии с ненулевой длиной и нулевой областью, а также для пустой геометрии.
2 для геометрии с ненулевой областью.
Объекты Point имеют размерность 0. Объекты LineString имеют размерность 1. Объекты Polygon имеют размерность 2. Размерности объектов MultiPoint, MultiLineString и MultiPolygon такие же, как размерности тех элементов, из которых они состоят.
4.2.3. Класс Point
Point геометрия, которая представляет одиночное расположение в координатном пространстве.
Примеры Point
Вообразите крупномасштабную карту мира с многими городами. Объект Point мог бы представлять каждый город.
На городской карте объект Point мог бы представлять автобусную остановку (Stylus советует "bus stop" писать как "останов шины", зараза с русскими программистами).
Свойства Point
Значение X.
Значение Y.
Point определена как нуль-мерная геометрия.
Границей Point является пустой набор.
4.2.4. Класс Curve
Curve одномерная геометрия, обычно представляемая последовательностью точек. Специфические подклассы Curve определяют тип интерполяции между пунктами (точками). Curve non-instantiable.
Свойства Curve
Curve имеет координаты пунктов.
Curve определена как одномерная геометрия.
Curve проста, если не проходит через ту же самую отметку дважды.
Curve закрыта, если отметка начала равна оконечной точке.
Граница закрытой Curve пуста.
Граница не закрытой Curve состоит из двух оконечных точек.
Curve, которая является простой и закрытой, LinearRing.
4.2.5. Класс LineString
LineString это Curve с линейной интерполяцией между пунктами (точками).
Примеры LineString:
На всемирной карте объекты LineString могли бы представлять реки.
В городской карте объекты LineString могли бы представлять любые проходы.
Свойства LineString
LineString имеет координаты сегментов, определенных каждой последовательной парой пунктов.
LineString является Line, если это состоит из точно двух пунктов.
LineString является LinearRing, если закрыта и проста.
4.2.6. Класс Surface
Surface двумерная геометрия. Это non-instantiable класс. Есть instantiable подкласс: Polygon.
Свойства Surface
Surface определен как двумерная геометрия.
OpenGIS определяет простой Surface как геометрию, которая состоит из одиночной заплаты, связанной с одной внешней границей и нулем или более внутренними границами.
Граница простого Surface представляет собой набор закрытых кривых, соответствующих внешним и внутренним границам.
4.2.7. Класс Polygon
Polygon плоский вариант Surface, представляющий многостороннюю геометрию. Это определено одиночной внешней границей и нулем или более внутренними границами, где каждая внутренняя граница определяет отверстие в Polygon.
Пример Polygon.
На карте области объекты Polygon могли бы представлять леса, районы и так далее.
Утверждения Polygon.
Граница Polygon состоит из набора объектов LinearRing (то есть, объектов LineString, которые являются простыми и закрытыми), которые составляют внешние и внутренние границы.
Polygon не имеет никаких пересечений. Кольца в границе Polygon могут пересекаться в Point, но только как тангенс.
Polygon не имеет никаких строк, выбросов или проколов.
Polygon имеет внутреннюю структуру, которая является связанным набором отметок.
Polygon может иметь отверстия. Внешний Polygon с отверстиями не связан. Каждое отверстие определяет связанный компонент внешних.
Предшествующие утверждения делают Polygon простой геометрией.
4.2.8. Класс GeometryCollection
GeometryCollection геометрия, которая является совокупностью одной или большего количества конфигураций любого класса.
Все элементы в GeometryCollection должны быть в той же самой пространственной системе ссылки (то есть, в той же самой системе координат). Не имеется никаких других ограничений на элементы GeometryCollection, хотя подклассы GeometryCollection, описанных в следующих разделах могут ограничивать членство. Ограничения могут быть основаны на:
Тип элемента (например, MultiPoint может содержать только элементы Point).
Размерность.
Ограничения на степень пространственного перекрытия между элементами.
4.2.9. Класс MultiPoint
MultiPoint совокупность геометрии, составленная из элементов Point. Пункты (точки) всегда не связаны или упорядочены.
Примеры MultiPoint:
На всемирной карте MultiPoint мог бы представлять цепочку маленьких изолированных островов.