MySQL: руководство профессионала
Шрифт:
WKB использует однобайтовые целые числа без знака, целые числа без знака с четырьмя байтами и числа двойной точности с восемью байтами (IEEE 754). Байт равен восьми битам.
Например, значение WKB, которое соответствует POINT(1 1) состоит из этой последовательности 21 байтов (каждый представляется здесь двумя шестнадцатеричными цифрами):0101000000000000000000F03F000000000000F03F
Последовательность может быть разделена на эти компоненты:Byte order : 01
WKB type : 01000000
X: 000000000000F03F
Y: 000000000000F03F
Представление компонента
Byte order может быть 0 или 1, чтобы указать little-endian или big-endian формат хранения. little-endian и big-endian также известны как Network Data Representation (NDR) и External Data Representation (XDR), соответственно.
WKB type задает код, который указывает тип геометрии. Значения от 1 до 7 указывают Point, LineString, Polygon, MultiPoint, MultiLineString, MultiPolygon и GeometryCollection.
Значение Point имеет координаты X и Y, каждпя представляемая как значение двойной точности.
WKB-значения для более сложных значений геометрии представляются более сложными структурами данных, как детализировано в спецификации OpenGIS.
4.4. Создание пространственной базы данных MySQL
Этот раздел описывает типы данных, которые Вы можете использовать для представления пространственных данных в MySQL и функции, доступные для создания и поиска пространственных значений.
4.4.1. Пространственные типы данных в MySQL
MySQL имеет типы данных, которые соответствуют классам OpenGIS. Часть этих типов хранит одиночные значения геометрии:
GEOMETRY
POINT
LINESTRING
POLYGON
GEOMETRY может сохранять значения геометрии любого типа. Другие типы с одиночным значением (POINT, LINESTRING и POLYGON) ограничивают их значения специфическим типом геометрии.
Другие типы данных хранят совокупности значений:
MULTIPOINT
MULTILINESTRING
MULTIPOLYGON
GEOMETRYCOLLECTION
GEOMETRYCOLLECTION может сохранять совокупность объектов любого типа. Другие типы совокупности (MULTIPOINT, MULTILINESTRING, MULTIPOLYGON и GEOMETRYCOLLECTION) ограничивают элементы совокупности имеющими специфический тип геометрии.
4.4.2. Создание пространственных значений
Этот раздел описывает, как создать пространственные значения, использующие функции Well-Known Text и Well-Known Binary, которые определены в стандарте OpenGIS, и применить MySQL-функции.
4.4.2.1. Создание значений геометрии через функции WKT
MySQL обеспечивает ряд функций, которые берут как входные параметры представление Well-Known Text и, факультативно, пространственный идентификатор системы ссылки (SRID). Они возвращают соответствующую геометрию.
GeomFromText принимает WKT любого типа геометрии как первый параметр. Реализация также обеспечивает специфические для типа функции для конструкции значений геометрии каждого типа.
GeomCollFromText(wkt[,srid]), GeometryCollectionFromText(wkt[,srid])
Создает
GeomFromText(wkt[,srid]), GeometryFromText(wkt[,srid])
Создает значение геометрии из любого типа, использующего WKT представление и SRID.
LineFromText(wkt[,srid]), LineStringFromText(wkt[,srid])
Создает значение LINESTRING, использующее WKT представление и SRID.
MLineFromText(wkt[,srid]), MultiLineStringFromText(wkt[,srid])
Создает значение MULTILINESTRING, использующее WKT представление и SRID.
MPointFromText(wkt[,srid]), MultiPointFromText(wkt[,srid])
Создает значение MULTIPOINT, использующее WKT представление и SRID.
MPolyFromText(wkt[,srid]), MultiPolygonFromText(wkt[,srid])
Создает значение MULTIPOLYGON, использующее WKT представление и SRID.
PointFromText(wkt[,srid])
Создает значение POINT, использующее WKT представление и SRID.
PolyFromText(wkt[,srid]), PolygonFromText(wkt[,srid])
Создает значение POLYGON, использующее WKT представление и SRID.
Спецификация OpenGIS также определяет следующие факультативные функции, которые MySQL не выполняет. Эти функции создают значения Polygon или MultiPolygon, основанные на WKT представлении совокупности колец или закрытых значений LineString. Эти значения могут пересекаться.
BdMPolyFromText(wkt,srid)
Создает значение MultiPolygon из MultiLineString в формате WKT, содержащем произвольную совокупность закрытых значений LineString.
BdPolyFromText(wkt,srid)
Создает значение Polygon из MultiLineString в формате WKT, содержащем произвольную совокупность закрытых значенийLineString.
4.4.2.2. Создание значенией геометрии с помощью функций WKB