summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--Docs/gis.txt874
1 files changed, 0 insertions, 874 deletions
diff --git a/Docs/gis.txt b/Docs/gis.txt
deleted file mode 100644
index 3556949d516..00000000000
--- a/Docs/gis.txt
+++ /dev/null
@@ -1,874 +0,0 @@
-
- OpenGIS <http://www.opengis.org> support in MySQL
-
-------------------------------------------------------------------------
-Note: Blue colored lines among the text is features not implemented yet.
-They are:
-
- * Spatial Reference Systems and their IDs (SRIDs) related things:
- o Functions like Length() and Area() assume planar coordinate
- system.
- o All objects are currently considered to be in the same
- planar coordinate system.
- * Function Length() on LineString and MultiLineString currently
- should be called as GLength().
-* No binary constructors like GeomFromWKB().
-
-We also have to add "PostGIS compatibility" sections.
-
-
- 1 Introduction
-
-MySQL implements a subset of *SQL2 with Geometry Types* environment
-proposed by OpenGIS consortium's *Simple Features Specification For
-SQL*. In this environment a geometry-valued column is implemented as a
-column whose SQL type is drawn from the set of Geometry Types. SQL
-server supports both textual and binary access to geometry.
-
-
- 2 OpenGIS Geometry Model in MySQL
-
-MySQL supports the Open GIS Geometry Model based hierarcy of spatial
-objects classes, which consists of:
-
- * Geometry
- o *Point*
- o Curve
- + *LineString*
- o Surface
- + *Polygon*
- o *GeometryCollection*
- + *MultiPoint*
- + MultiCurve
- # *MultiLineString*
- + MultiSurface
- # *MultiPolygon*
-
-The base *Geometry* class has subclasses for Point, Curve, Surface and
-GeometryCollection.
-
-Geometry, Curve, Surface, MultiCurve and MultiSurface are defined to be
-non-instantiable classes, it is not possible to create an object of
-these classes.
-
-Point, LineString, Polygon, GeometryCollection, MultiPoint,
-MultiLineString, MultiPolygon are instantiable classes (bolded on the
-hierarcy tree). MySQL provides a number of functions to construct
-instances of these classes.
-
-TODO: Each spatial object is associated with a Spatial Reference System,
-which describes the coordinate space in which the geometric object is
-defined.
-
-
- 2.1 Geometry
-
-Geometry is the root class of the hierarchy. Geometry is an abstract
-(non-instantiable) class. The instantiable subclasses of Geometry
-defined in this specification are restricted to 0, 1 and two-dimensional
-geometric objects that exist in two-dimensional coordinate space. All
-instantiable geometry classes are defined so that valid instances of a
-geometry class are topologically closed (i.e. all defined geometries
-include their boundary).
-
-
- 2.2 Point
-
-A *Point* is a 0-dimensional geometry and represents a single location
-in coordinate space. A Point in the case of 2D has a x-coordinate value
-and a y-coordinate value. In the case of more dimensions, a Point has a
-coordinate value for each dimension. The boundary of a Point is the
-empty set.
-
-
- 2.3 Curve
-
-A *Curve* is a one-dimensional geometric object usually stored as a
-sequence of points, with the subclass of Curve specifying the form of
-the interpolation between points. MySQL implementation defines only one
-subclass of Curve, LineString, which uses linear interpolation between
-points.
-
-A Curve is simple if it does not pass through the same point twice. A
-Curve is closed if its start point is equal to its end point. The
-boundary of a closed Curve is empty. A Curve that is simple and closed
-is a Ring. The boundary of a non-closed Curve consists of its two end
-points. A Curve is defined as topologically closed.
-
-
- 2.4 LineString, Line, LinearRing
-
-A LineString is a Curve with linear interpolation between points. Each
-consecutive pair of points defines a line segment. A Line is a
-LineString with exactly 2 points. A LinearRing is a LineString that is
-both closed and simple.
-
-
- 2.5 Surface
-
-A *Surface* is a two-dimensional geometric object. The OpenGIS Abstract
-Specification defines a simple Surface as consisting of a single 'patch'
-that is associated with one 'exterior boundary' and 0 or more 'interior'
-boundaries. Simple surfaces in three-dimensional space are isomorphic to
-planar surfaces. Polyhedral surfaces are formed by 'stitching' together
-simple surfaces along their boundaries, polyhedral surfaces in
-three-dimensional space may not be planar as a whole.
-
-The boundary of a simple Surface is the set of closed curves
-corresponding to its exterior and interior boundaries.
-
-The only instantiable subclass of Surface defined in this specification,
-Polygon, is a simple Surface that is planar.
-
-
- 2.6 Polygon
-
-A Polygon is a planar Surface, defined by 1 exterior boundary and 0 or
-more interior boundaries. Each interior boundary defines a hole in the
-Polygon. The assertions for polygons (the rules that define valid
-polygons) are:
-
- * Polygons are topologically closed.
- * The boundary of a Polygon consists of a set of LinearRings (i.e.
- LineStrings which are both simple and closed) that make up its
- exterior and interior boundaries.
- * No two rings in the boundary cross, the rings in the boundary of a
- Polygon may intersect at a Point but only as a tangent.
- * A Polygon may not have cut lines, spikes or punctures.
- * The Interior of every Polygon is a connected point set.
- * The Exterior of a Polygon with 1 or more holes is not connected.
-Each hole defines a connected component of the Exterior.
-
-In the above assertions, Interior, Closure and Exterior have the
-standard topological definitions. The combination of 1 and 3 make a
-Polygon a Regular Closed point set. Polygons are simple geometries.
-
-
- 2.6 GeometryCollection
-
-A *GeometryCollection* is a geometry that is a collection of 1 or more
-geometries of any class. All the elements in a GeometryCollection must
-be in the same Spatial Reference (i.e. in the same coordinate system).
-GeometryCollection places no other constraints on its elements. However
-subclasses of GeometryCollection described below may restrict membership
-based on dimension and may also place other constraints on the degree of
-spatial overlap between elements.
-
-
- 2.7 MultiPoint
-
-A *MultiPoint* is a 0 dimensional geometric collection. The elements of
-a MultiPoint are restricted to Points. The points are not connected or
-ordered. A MultiPoint is simple if no two Points in the MultiPoint are
-equal (have identical coordinate values). The boundary of a MultiPoint
-is the empty set.
-
-
- 2.8 MultiCurve
-
-A MultiCurve is a one-dimensional geometry collection whose elements are
-Curves. MultiCurve is a non-instantiable class, it defines a set of
-methods for its subclasses and is included for reasons of extensibility.
-
-A MultiCurve is simple if and only if all of its elements are simple,
-the only intersections between any two elements occur at points that are
-on the boundaries of both elements.
-
-The boundary of a MultiCurve is obtained by applying the "mod 2 union
-rule": A point is in the boundary of a MultiCurve if it is in the
-boundaries of an odd number of elements of the MultiCurve.
-
-A MultiCurve is closed if all of its elements are closed. The boundary
-of a closed MultiCurve is always empty. A MultiCurve is defined as
-topologically closed.
-
-
- 2.9 MultiLineString
-
-A *MultiLineString* is a MultiCurve whose elements are LineStrings.
-
-
- 2.10 MultiSurface
-
-A MultiSurface is a two-dimensional geometric collection whose elements
-are surfaces. The interiors of any two surfaces in a MultiSurface may
-not intersect. The boundaries of any two elements in a MultiSurface may
-intersect at most at a finite number of points.
-
-MultiSurface is a non-instantiable class in this specification, it
-defines a set of methods for its subclasses and is included for reasons
-of extensibility. The instantiable subclass of MultiSurface is
-MultiPolygon, corresponding to a collection of Polygons.
-
-
- 2.11 MultiPolygon
-
-A MultiPolygon is a MultiSurface whose elements are Polygons.
-
-The assertions for MultiPolygons are :
-
- * The interiors of 2 Polygons that are elements of a MultiPolygon
- may not intersect.
- * The Boundaries of any 2 Polygons that are elements of a
- MultiPolygon may not cross and may touch at only a finite number
- of points. (Note that crossing is prevented by assertion 1 above).
- * A MultiPolygon is defined as topologically closed.
- * A MultiPolygon may not have cut lines, spikes or punctures, a
- MultiPolygon is a Regular, Closed point set.
- * The interior of a MultiPolygon with more than 1 Polygon is not
- connected, the number of connected components of the interior of a
-MultiPolygon is equal to the number of Polygons in the MultiPolygon.
-
-The boundary of a MultiPolygon is a set of closed curves (LineStrings)
-corresponding to the boundaries of its element Polygons. Each Curve in
-the boundary of the MultiPolygon is in the boundary of exactly 1 element
-Polygon, and every Curve in the boundary of an element Polygon is in the
-boundary of the MultiPolygon.
-
-
- 3 Exchange of spatial data
-
-MySQL provides binary and textual mechanismes to exchange spatial data.
-Exchange is provided via so called Well Known Binary (WKB) and Well
-Known Textual (WKT) representations of spatial data proposed by OpenGIS
-specifications.
-
-
- 3.1 Well-known Text representation (WKT)
-
-The Well-known Text (WKT) representation of Geometry is designed to
-exchange geometry data in textual format.
-
-WKT is defined below in Bechus-Naur forms:
-
- * the notation {}* denotes 0 or more repetitions of the tokens
- within the braces;
-* the braces do not appear in the output token list.
-
-The text representation of the implemented instantiable geometric types
-conforms to this grammar:
-
-<Geometry Tagged Text> :=
- <Point Tagged Text>
- | <LineString Tagged Text>
- | <Polygon Tagged Text>
- | <MultiPoint Tagged Text>
- | <MultiLineString Tagged Text>
- | <MultiPolygon Tagged Text>
- | <GeometryCollection Tagged Text>
-
-<Point Tagged Text> :=
-
- POINT <Point Text>
-
-<LineString Tagged Text> :=
-
- LINESTRING <LineString Text>
-
-<Polygon Tagged Text> :=
-
- POLYGON <Polygon Text>
-
-<MultiPoint Tagged Text> :=
-
- MULTIPOINT <Multipoint Text>
-
-<MultiLineString Tagged Text> :=
-
- MULTILINESTRING <MultiLineString Text>
-
-<MultiPolygon Tagged Text> :=
-
- MULTIPOLYGON <MultiPolygon Text>
-
-<GeometryCollection Tagged Text> :=
-
- GEOMETRYCOLLECTION <GeometryCollection Text>
-
-<Point Text> := EMPTY | ( <Point> )
-
-<Point> := <x> <y>
-
-<x> := double precision literal
-
-<y> := double precision literal
-
-<LineString Text> := EMPTY
-
- | ( <Point > {, <Point > }* )
-
-<Polygon Text> := EMPTY
-
- | ( <LineString Text > {, < LineString Text > }*)
-
-<Multipoint Text> := EMPTY
-
- | ( <Point Text > {, <Point Text > }* )
-
-<MultiLineString Text> := EMPTY
-
- | ( <LineString Text > {, < LineString Text > }* )
-
-<MultiPolygon Text> := EMPTY
-
- | ( < Polygon Text > {, < Polygon Text > }* )
-
-<GeometryCollection Text> := EMPTY
-
- | ( <Geometry Tagged Text> {, <Geometry Tagged Text> }* )
-
-
- WKT examples
-
-Examples of textual representations of Geometry objects are shown below:
-
- * |POINT(10 10)| - a Point
- * |LINESTRING( 10 10, 20 20, 30 40)| - a LineString with three points
- * |POLYGON((10 10, 10 20, 20 20,20 15, 10 10))| - a Polygon with one
- exterior ring and 0 interior rings
- * |MULTIPOINT(10 10, 20 20)| - a MultiPoint with two Points
- * |MULTILINESTRING((10 10, 20 20), (15 15, 30 15))| - a
- MultiLineString with two LineStrings
- * |MULTIPOLYGON(((10 10, 10 20, 20 20, 20 15, 10 10)), ((60 60, 70
- 70, 80 60, 60 60 ) ))| - a MultiPolygon with two Polygons
- * |GEOMETRYCOLLECTION( POINT (10 10),POINT (30 30), LINESTRING (15
- 15, 20 20))| - a GeometryCollection consisting of two Points and
-one LineString
-
-
- 3.2 Well-known Binary representation (WKB)
-
-Well Known Binary Representations is proposed by OpenGIS specifications
-to exchange geometry data in binary format. This is WKB description:
-
-// Basic Type definitions
-// byte : 1 byte
-// uint32 : 32 bit unsigned integer (4 bytes)
-// double : double precision number (8 bytes)
-// Building Blocks : Point, LinearRing
-
-Point {
- double [numDimentions];
-};
-
-LinearRing {
- uint32 numPoints;
- Point points[numPoints];
-}
-
-enum wkbGeometryType {
- wkbPoint = 1,
- wkbLineString = 2,
- wkbPolygon = 3,
- wkbMultiPoint = 4,
- wkbMultiLineString = 5,
- wkbMultiPolygon = 6,
- wkbGeometryCollection = 7
-};
-
-enum wkbByteOrder {
- wkbXDR = 0, // Big Endian
- wkbNDR = 1 // Little Endian
-};
-
-WKBPoint {
- byte byteOrder;
- uint32 wkbType; // 1
- Point point;
-}
-
-WKBLineString {
- byte byteOrder;
- uint32 wkbType; // 2
- uint32 numPoints;
- Point points[numPoints];
-}
-
-WKBPolygon {
- byte byteOrder;
- uint32 wkbType; // 3
- uint32 numRings;
- LinearRing rings[numRings];
-}
-
-WKBMultiPoint {
- byte byteOrder;
- uint32 wkbType; // 4
- uint32 num_wkbPoints;
- WKBPoint WKBPoints[num_wkbPoints];
-}
-
-WKBMultiLineString {
- byte byteOrder;
- uint32 wkbType; // 5
- uint32 num_wkbLineStrings;
- WKBLineString WKBLineStrings[num_wkbLineStrings];
-}
-
-wkbMultiPolygon {
- byte byteOrder;
- uint32 wkbType; // 6
- uint32 num_wkbPolygons;
- WKBPolygon wkbPolygons[num_wkbPolygons];
-}
-
-WKBGeometry {
- union {
- WKBPoint point;
- WKBLineString linestring;
- WKBPolygon polygon;
- WKBGeometryCollection collection;
- WKBMultiPoint mpoint;
- WKBMultiLineString mlinestring;
- WKBMultiPolygon mpolygon;
- }
-
-};
-
-WKBGeometryCollection {
- byte byte_order;
- uint32 wkbType; // 7
- uint32 num_wkbGeometries;
- WKBGeometry wkbGeometries[num_wkbGeometries];
-}
-
-
- 3.3 MySQL data types for spatial objects
-
-MySQL implementation of OpenGIS provides the *GEOMETRY* data type to be
-used in CREATE TABLE statements. For example, this statement creates a
-table *geom* with spatial field *g*:
-
-CREATE TABLE geom (
- g Geometry;
-);
-
-A field of *GEOMETRY* type can store a spatial objects of any OpenGIS
-geometry class described above.
-
-
- 3.4 Internal spatial data representation
-
-Internally (in *.MYD* files) spatial objects are stored in *WKB*,
-combined with object's *SRID* (a numeric ID of Spatial Reference System
-object associated with). During spatial analysis, for example,
-calculating the fact that one object crosses another one, only those
-with the same *SRID* are accepted.
-
-*SRID* may affect a way in which various spatial characteristics are
-calculated. For example, in different coordinate systems distance
-between two objects may differ even objects have the same coordinates,
-like distance on plane coordinate system and distance on geocentric
-(coordinates on Earth surface) systems are different things.
-
-There is a plan to provide a number of commonly used coordinate systems
-in MySQL OpenGIS implementation.
-
-
- 3.5 INSERTing spatial objects
-
-Spatial data can be INSERTed using a spatial constructor. The term
-*spatial constructor* is used in this manual to refer to any function
-which can construct a value of GEOMETRY type, i.e. an internal MySQL
-representation of spatial data.
-
-
- 3.5.1 Textual spatial constructors
-
-Textual spatial constructors take a gemometry description in WKT and
-built GEOMETRY value.
-
- * |*GeomFromText(geometryTaggedText String [, SRID
- Integer]):Geometry *| - constructs a Geometry value from its
- well-known textual representation.
-
- |*GeomFromText()*| function accepts a WKT of any Geometry class as
- it's first argument.
-
- For construction of Geometry values restricted to a particular
- subclass, an implementation also provides a class-specific
- construction function for each instantiable subtype as described
- in the list below:
-
- * |*PointFromText(pointTaggedText String [,SRID Integer]):Point *| -
- constructs a Point
-
- * |*LineFromText(lineStringTaggedText String [,SRID
- Integer]):LineString *| - constructs a LineString
-
- . |*LineStringFromText()*| - synonym for LineFromText().
-
- * |*PolyFromText(polygonTaggedText String [,SRID Integer]):Polygon
- *|- constructs a Polygon
-
- |*PolygonFromText()*| - synonym for PolyFromText().
-
- * |*MPointFromText(multiPointTaggedText String [,SRID
- Integer]):MultiPoint *| - constructs a MultiPoint
-
- |*MultiPointFromText()*| - synonym for MPointFromText().
-
- * |*MLineFromText(multiLineStringTaggedText String [,SRID
- Integer]):MultiLineString *| - constructs a MultiLineString
-
- |*MultiLineStringFromText()*| - synonym for MLineFromText().
-
- * |*MPolyFromText(multiPolygonTaggedText String [,SRID
- Integer]):MultiPolygon *| - constructs a MultiPolygon
-
- |*MultiPolygonFromText()*| - synonym for MPolyFromText().
-
- * |*GeomCollFromText(geometryCollectionTaggedText String [,SRID
- Integer]):GeomCollection *| - constructs a GeometryCollection
-
-Usage examples:
-
-INSERT INTO geom VALUES (GeomFromText('POINT(1 1)'))
-INSERT INTO geom VALUES (GeomFromText('LINESTRING(0 0,1 1,2 2)'))
-INSERT INTO geom VALUES (GeomFromText('POLYGON((0 0,10 0,10 10,0 10,0 0),(5 5,7 5,7 7,5 7, 5 5))'))
-INSERT INTO geom VALUES (GeomFromText('GEOMETRYCOLLECTION(POINT(1 1),LINESTRING(0 0,1 1,2 2,3 3,4 4))'))
-
-The second argument of spatial constructirs, described above, is
-currently ignored, It will be used to specify SRID in the future.
-Nowdays, it is added for reasons of compatibility with OpenGIS
-specifications and PostGIS implementation.
-
-As an optional feature, an implementation may also support building of
-Polygon or MultiPolygon values given an arbitrary collection of possibly
-intersecting rings or closed LineString values. Implementations that
-support this feature should include the following functions:
-
- * |*BdPolyFromText(multiLineStringTaggedText String, SRID
- Integer):Polygon *| - constructs a Polygon given an arbitrary
- collection of closed linestrings as a MultiLineString text
- representation.
- * |*BdMPolyFromText(multiLineStringTaggedText String, SRID
- Integer):MultiPolygon *| - constructs a MultiPolygon given an
- arbitrary collection of closed linestrings as a MultiLineString
-text representation.
-
-
- 3.5.2 Binary spatial constructors
-
- * |*GeomFromWKB(WKBGeometry Binary, SRID Integer):Geometry *| -
- constructs a Geometry value given its well-known binary
- representation.
-
- |*GeomFromWKB()*| function can accept in it's first argument a WKB
- of Geometry of any class. For construction of Geometry values
- restricted to a particular subclass, an implementation also
- provides a class-specific construction function for each
- instantiable subclass as described in the list below:
-
- * |*PointFromWKB(WKBPoint Binary, SRID Integer):Point - *|constructs
- a Point
- * |* LineFromWKB(WKBLineString Binary, SRID Integer):LineString *| -
- constructs a LineString
- * |* PolyFromWKB(WKBPolygon Binary, SRID Integer):Polygon *| -
- constructs a Polygon
- * |* MPointFromWKB(WKBMultiPoint Binary, SRID Integer):MultiPoint *|
- - constructs a MultiPoint
- * |* MLineFromWKB(WKBMultiLineString Binary, SRID
- Integer):MultiLineString *| - constructs a MultiLineString
- * |* MPolyFromWKB(WKBMultiPolygon Binary, SRID Integer):
- MultiPolygon *| - constructs a MultiPolygon
- * |* GeomCollFromWKB(WKBGeometryCollection Binary, SRID Integer):
-GeomCollection *| - constructs a GeometryCollection
-
-As an optional feature, an implementation may also support the uilding'
-of Polygon or MultiPolygon values given an arbitrary collection of
-possibly intersecting rings or closed LineString values. Implementations
-that support this feature should include the following functions:
-
- * |* BdPolyFromWKB (WKBMultiLineString Binary,SRID Integer): Polygon
- *| - constructs a Polygon given an arbitrary collection of closed
- linestrings as a MultiLineString binary representation.
- * |*BdMPolyFromWKB(WKBMultiLineString Binary, SRID
- Integer):MultiPolygon *| - constructs a MultiPolygon given an
- arbitrary collection of closed linestrings as a MultiLineString
-binary representation.
-
-Inserting in *WKB* assumes that |GeomFromWKB()| function argument
-contains a buffer with a correctly formed spatial object in WKB. In ODBC
-applications it can be done using binding of argument. One also can
-insert object in *WKB* using |mysql_escape_string()| in |libmysqlclient|
-applications.
-
-For example:
-
-INSERT INTO geom VALUES (GeomFromWKB(buf,SRID));
-
-where |buf| is a binary buffer with a spatial object in *WKB*
-representation.
-
-
- 3.5 SELECTing spatial objects
-
-Spatial objects are selected either in *WKT* or *WKB* representation by
-use of AsText() and AsBinary() functions correspondently.
-
-
-mysql> select AsText(g) as g from geom;
-+-------------------------+
-| g |
-+-------------------------+
-| POINT(1 1) |
-| LINESTRING(0 0,1 1,2 2) |
-+-------------------------+
-2 rows in set (0.00 sec)
-
-mysql>
-
-The query:
-
-SELECT AsBinary(g) FROM geom
-
-returns a BLOB which contains *WKB* representation of object.
-
-
- 4 Functions for spatial analysis
-
-
- 4.1 Basic functions on Geometry
-
- * |*AsText(g:Geometry):String*| - Exports this Geometry to a
- specific well-known text representation of Geometry.
- * |*AsBinary(g:Geometry):Binary*| - Exports this Geometry to a
- specific well-known binary representation of Geometry.
- * |*GeometryType(g:Geometry):String*| - Returns the name of the
- instantiable subtype of Geometry of which this Geometry instance
- is a member. The name of the instantiable subtype of Geometry is
- returned as a string.
- * |*Dimension(g:Geometry):Integer*| - The inherent dimension of this
- Geometry object, which must be less than or equal to the
- coordinate dimension. This specification is restricted to
- geometries in two-dimensional coordinate space.
- * |*IsEmpty(g:Geometry):Integer*| - Returns 1 (TRUE) if this
- Geometry is the empty geometry . If true, then this Geometry
- represents the empty point set, , for the coordinate space.
- * |*IsSimple(g:Geometry):Integer *| - Returns 1 (TRUE) if this
- Geometry has no anomalous geometric points, such as self
- intersection or self tangency. The description of each
- instantiable geometric class includes the specific conditions that
- cause an instance of that class to be classified as not simple.
- * |*SRID(g:Geometry):Integer*| - Returns the Spatial Reference
- System ID for this Geometry.
- * |*Distance(g1:Geometry,g2:Geometry):Double*| - the shortest
-distance between any two points in the two geometries.
-
-
- 4.2 Functions for specific geometry type
-
-
- GeometryCollection functions
-
- * *NumGeometries(g:GeometryCollection ):Integer * -Returns the
- number of geometries in this GeometryCollection.
- * *GeometryN(g:GeometryCollection,N:integer):Geometry * -Returns the
-Nth geometry in this GeometryCollection.
-
-
- Point functions
-
- * *X(p:Point):Double* -The x-coordinate value for this Point.
-* *Y(p:Point):Double* -The y-coordinate value for this Point.
-
-
- LineString functions
-
- * *StartPoint(l:LineString):Point* The start point of this LineString.
- * *EndPoint(l:LineString):Point* The end point of this LineString.
- * *PointN(l:LineString,N:Integer):Point* Returns the specified point
- N in this Linestring.
- * *Length(l:LineString):Double* The length of this LineString in its
- associated spatial reference.
- * *IsRing(l:LineString):Integer* Returns 1 (TRUE) if this LineString
- is closed (StartPoint ( ) = EndPoint ( )) and this LineString is
- simple (does not pass through the same point more than once).
- * *IsClosed(l:LineString):Integer* Returns 1 (TRUE) if this
- LineString is closed (StartPoint ( ) = EndPoint ( )).
- * *NumPoints(l:LineString):Integer* The number of points in this
-LineString.
-
-
- MultiLineString functions
-
- * *Length(m:MultiLineString):Double* The Length of this
- MultiLineString which is equal to the sum of the lengths of the
- elements.
- * *IsClosed(m:MultiLineString):Integer* Returns 1 (TRUE) if this
- MultiLineString is closed (StartPoint() = EndPoint() for each
-LineString in this MultiLineString)
-
-
- Polygon functions
-
- * *Area(p:Polygon):Double* The area of this Polygon, as measured in
- the spatial reference system of this Polygon.
- * *Centroid(p:Polygon):Point* The mathematical centroid for this
- Polygon as a Point. The result is not guaranteed to be on this
- Polygon.
- * *PointOnSurface(p:Polygon):Point* A point guaranteed to be on this
- Polygon.
- * *NumInteriorRing(p:Polygon):Integer* Returns the number of
- interior rings in this Polygon.
- * *ExteriorRing(p:Polygon):LineString* Returns the exterior ring of
- this Polygon as a LineString.
- * *InteriorRingN(p:Polygon,N:Integer):LineString* Returns the Nth
-interior ring for this Polygon as a LineString.
-
-
- MultiPolygon functions
-
- * *Area(m:MultuSurface):Double* The area of this MultiPolygon, as
- measured in the spatial reference system of this MultiPolygon.
- * *Centroid(m:MultyPolygon):Point* The mathematical centroid for
- this MultiPolygon as a Point. The result is not guaranteed to be
- on this MultiPolygon.
- * *PointOnSurface(m:MultuPolygon):Point* A Point guaranteed to be on
-this MultiPolygon.
-
-Notes: /functions for specific geometry type retrun NULL if passed
-object type is incorrect. For example Area() returns NULL if object type
-is neither Polygon nor MultiPolygon/
-
-
- 4.3 Spatial operations (compound spatial constructors)
-
- * |*Envelope(g:Geometry):Geometry*|The minimum bounding box for this
- Geometry, returned as a Geometry. The polygon is defined by the
- corner points of the bounding box
- |POLYGON((MINX,MINY),(MAXX,MINY),(MAXX,MAXY),(MINX,MAXY),(MINX,MINY))|.
-
- * |*Boundary(g:Geometry):Geometry*| - returns the closure of the
- combinatorial boundary of this Geometry.
- * |*Intersection(g1,g2:Geometry):Geometry*| - a geometry that
- represents the point set intersection of g1 with g2.
- * |*Union(g1,g2:Geometry):Geometry*| - a geometry that represents
- the point set union of g1 with g2.
- * |*Difference(g1,g2:Geometry):Geometry*| - a geometry that
- represents the point set difference of g1 with g2.
- * |*SymDifference(g1,g2:Geometry):Geometry*| - a geometry that
- represents the point set symmetric difference of g1 with g2.
- * |*Buffer(g:Geometry,distance:Double):Geometry*| - a geometry that
- represents all points whose distance from g is less than or equal
- to distance.
- * |*ConvexHull(g:Geometry):Geometry*| - a geometry that represents
-the convex hull of g.
-
-
- 4.4 Functions for testing Spatial Relations between geometric objects
-
- * |*Equals(g1,g2)*| - Returns 1 if g1 is spatially equal to g2.
- * |*Disjoint(g1,g2)*| - Returns 1 if g1 is spatially disjoint from g2.
- * |*Intersects(g1,g2)*| - Returns 1 if g1 spatially intersects g2.
- * |*Touches(g1,g2)*| - Returns 1 if g1 spatially touches g2.
- * |*Crosses(g1,g2)*| - Returns 1 if g1 spatially crosses g2.
- * |*Within(g1,g2)*| - Returns 1 if g1 is spatially within g2.
- * |*Contains(g1,g2)*| - Returns 1 if g1 spatially contains g2.
-* |*Overlaps(g1,g2)*| - Returns 1 if g1 spatially overlaps g2.
-
-
- 5 Optimizing spatial analysis
-
-
- 5.1 MBR
-
-MBR is a minimal bounding rectangle (box) for spatial object. It can be
-represented as a set of min and max values of each dimension.
-
-For example:
-
-(Xmin,Xmax,Ymin,Ymax)
-
-
- 5.2 Using SPATIAL indexes
-
-To optimize spatial object relationships analysis it is possible to
-create a spatial index on geometry field using R-tree algorythm. R-tree
-based spatial indexes store MBRs of spatial objects as a key values.
-
-CREATE SPATIAL INDEX gind ON geom (g);
-
-Or together with table definition:
-
-CREATE TABLE geom (
- g GEOMETRY,
- SPATIAL INDEX(g)
-);
-
-Optimizer attaches R-tree based SPATIAL index when a query with spatial
-objects relationship functions is executed in WHERE clause.
-
-For example:
-
-SELECT geom.name FROM geom
- WHERE Within(geom.g,GeomFromText('POLYGON((0 0, 1 0, 1 1, 0 1, 0 0))',SRID));
-
-
- 8 OpenGIS extensions implemented in MySQL
-
-MySQL provides it's own constructors to build geometry objects:
-
- * |*Point(double,double,SRID)*| - constructs a geometry of Point
- class using it's coordinates and SRID.
- * |*MultiPoint(Point,Point,...,Point)*| - constructs a MultiPoint
- using Points. When any argument is not a geometry of Point class
- the return value is NULL.
- * |*LineString(Point,Point,...,Point)*| - constructs a LineString
- from a number of Points. When any argument is not a geometry of
- Point class the return value is NULL. When the number of Points is
- less than two the return value is NULL.
- * |*MultiLineString(LineString,LineString,...,LineString)*| -
- constructs a MultiLineString using using LineStrings. When any
- argument is not a geometry of LineStringClass return value is NULL.
- * |*Polygon(LineString,LineString,...,LineString)*| - constructs a
- Polygon from a number of LineStrings. When any argument is not a
- LinearRing (i.e. not closed and simple geometry of class
- LineString) the return value is NULL.
- * |*MultiPolygon(Polygon,Polygon,...,Polygon)*| - constructs a
- MultiPolygon from a set of Polygons. When any argument is not a
- Polygon, the rerurn value is NULL.
- * |*GeometryCollection(Geometry,Geometry,..,Geometry)*| - constucts
- a GeometryCollection. When any argument is not a valid geometry
-object of any instantiable class, the return value is NULL.
-
-The above functions (except Point()) return NULL if arguments are not in
-the same spatial reference system (i.e. have different SRIDs).
-
-
- Examples:
-
-INSERT INTO geom SELECT Point(x,y,SRID) FROM coords;
-SELECT AsText(g) FROM geom WHERE
- Contains(Polygon(LineString(Point(0,0),Point(0,1),Point(1,1),Point(1,0),Point(0,0)),SRID),geom.g);
-
-
- 9 Things that differ in MySQL implemention and OpenGIS specifications
-
-
- 9.1 Single GEOMETRY type
-
-Besides a GEOMETRY type, OpenGIS consortium specifications suggest the
-implementation of several spatial field types correspondent to every
-instansiable object subclass. For example a *Point* type is proposed to
-restrict data stored in a field of this type to only Point OpenGIS
-subclass. MySQL provides an implementation of single GEOMETRY type which
-doesn't restrict objects to certain OpenGIS subclass. Other proposed
-spatial field types are mapped into GEOMETRY type, so all these types
-can be used as a symonym for GEOMETRY: POINT, MULTIPOINT, LINESTRING,
-MULTILINESTRING, POLYGON, MULTIPOLYGON.
-
-
- 9.2 No additional Metadata Views
-
-OpenGIS specifications propose several additional metadata views. For
-example, a system view named GEOMETRY_COLUMNS contains a description of
-geometry columns, one row for each geometry column in the database.
-
-
- 9.3 No functions to add/drop spatial columns
-
-OpenGIS assumes that columns can be added/dropped using
-AddGeometryColumn() and DropGeometryColumn() functions correspondently.
-In MySQL implementation one should use ALTER TABLE instead.