Geospatial Data
Geospatial data is information that identifies geographic features, locations, and boundaries on Earth. By using geospatial data, you can store and analyze geographical information. Points, LineStrings, and areas are defined through coordinates and saved in Exasol as GEOMETRY objects. GEOMETRY columns can optionally have an SRID (Spatial reference system identifier, see EXA_SPATIAL_REF_SYS for more information) a reference coordinate system, which is a kind of constraint.
The GEOMETRY columns are filled with strings (for example, 'POINT(2 5)'). If you read this data externally by the drivers, this data is automatically converted to strings. The same applies to commands IMPORT and EXPORT.
For geospatial objects, a multitude of functions are provided to execute calculations and operations.
Geospatial Objects
The following table provides you with a list of different types of geospatial objects in Exasol:
Constructor  Description 

GEOMETRY  General abstraction of any geospatial objects 
POINT (X Y)  Point within the twodimensional area 
LINESTRING (X Y, X Y,...)  LineString which connects several twodimensional Points 
LINEARRING (X Y, X Y,...)  A linear ring is a LineString whose start and end points are identical 
POLYGON ((X Y,...)[,(X Y,...),...])  Area which is defined by a linear ring and an optional list of holes within this area. 
GEOMETRYCOLLECTION (geometry,...)  A collection of any geospatial objects 
MULTIPOINT (X Y,...)  Set of Points 
MULTILINESTRING ((X Y,...),...)  Set of LineStrings 
MULTIPOLYGON ((X Y,...),...)  Set of Polygons 
Instead of numerical arguments, you can also use the keyword EMPTY for creating an empty set of an object (for example, POLYGON EMPTY)
Example
POINT(2 5)  PT
LINESTRING(11 1, 15 2, 15 10)  L
POLYGON((5 1, 5 5, 9 7, 10 1, 5 1),
(6 2, 6 3, 7 3, 7 2, 6 2))  PG
MULTIPOINT(0.1 1.4, 2.2 3, 1 6.4)
MULTILINESTRING((0 1, 2 3, 1 6), (4 4, 5 5))
MULTIPOLYGON(((0 0, 0 2, 2 2, 3 1, 0 0)),
((4 6, 8 9, 12 5, 4 6), (8 6, 9 6, 9 7, 8 7, 8 6)))
GEOMETRYCOLLECTION(POINT(2 5), LINESTRING(1 1, 15 2, 15 10))
Where geometry data types include
 POINT  p
 LINESTRING  ls
 MULTILINESTRING  mls
 POLYGON  pg
 MULTIPOLYGON  mp
 GEOMETRY  g
 GEOMETRYCOLLECTION  gc
 INTEGER  n
Geospatial Functions
Exasol provides many functions to execute operations and mathematical calculations on geospatial objects. The arguments of the functions mainly consist of geospatial objects as described previous section.
Function  Description  

Point Functions  
ST_X(P)  X coordinate of a Point  
ST_Y(P)  Y coordinate of a Point  
(Multi)LineString Functions  
ST_ENDPOINT(ls)  End point of a LineString  
ST_ISCLOSED(mls)  Defines whether all contained LineStrings are rings, that is, whether their start and end points are identical.  
ST_ISRING(ls)  Defines whether a LineString is a closed ring, that is, start and end points are identical.  
ST_LENGTH(mls)  Length of a LineString or the sum of lengths of all objects of a MultiLineString  
ST_NUMPOINTS(ls)  Number of Points within the LineString  
ST_POINTN(ls,n)  The n^{th} point of a LineString, starting with 1. Returns NULL if ST_NUMPOINTS (ls)<n  
ST_STARTPOINT(ls)  Start point of a LineString  
(Multi)Polygon Functions  
ST_AREA(mp)  Area of a polygon or sum of areas of all objects of a MultiPolygon  
ST_EXTERIORRING(pg)  Outer ring of the object  
ST_INTERIORINGN(pg,n)  The n^{th} hole of a polygon, starting with 1. Returns NULL if ST_NUMINTERIORRINGS(pg)<n  
ST_NUMINTERIORRINGS(pg)  Number of holes within a Polygon  
GeometryCollection Functions  
ST_GEOMETRYN(gc,n)  The n^{th} object of a GeometryCollection, starting with 1. Returns NULL if ST_NUMGEOMETRIES(gc)<n.  
ST_NUMGEOMETRIES(gc)  Number of objects within a collection of geometry objects  
General Functions  
ST_BOUNDARY(g)  Geometric boundary of a geospatial object (for example, the end points of a LineString or the outer LinearRing of a Polygon).  
ST_BUFFER(g,n)  Returns a geospatial object, whose points have maximal distance n to the first argument. This is similar to an extension of the borders of an object. Around the edges, some sort of divided circle is created which is approximated by a number of points.  
ST_CENTROID(g)  Geometric center of mass of an object  
ST_CONTAINS(g,g)  Defines whether the first object fully contains the second one  
ST_CONVEXHULL(g)  Convex hull of a geospatial object  
ST_CROSSES(g,g) 
Defines whether the two objects cross each other. This is the case if,


ST_DIFFERENCE(g,g)  Difference set of two geospatial objects  
ST_DIMENSION(g)  Dimension of a geospatial object (for example, 0 for Points, 1 for LineStrings and 2 for Polygons).  
ST_DISJOINT(g,g)  Defines whether two geospatial objects are disjoint, i.e. their intersection is empty  
ST_DISTANCE(g,g)  Minimal distance between two geospatial objects  
ST_ENVELOPE(g)  Smallest rectangle which contains the geospatial object  
ST_EQUALS(g,g)  Defines whether two geospatial objects describe the same geometric object. For two objects g1 and g2 this is the case if ST_WITHIN(g1,g2) and ST_WITHIN(g2,g1)  
ST_FORCE2D(g)  Makes a 2D object out of a 3D object, which means that it ignores the third coordinate. This function can be necessary since Exasol does not support 3D objects  
ST_GEOMETRYTYPE(g)  Type of the geospatial object as string (for example, 'POINT' or 'MULTIPOLYGON')  
ST_INTERSECTION(g,g)  Intersection of two geospatial objects  
ST_INTERSECTION(g)  Intersection of two geospatial objects (aggregated)  
ST_INTERSECTS(g,g)  Defines whether an intersection of two geospatial objects exists  
ST_ISEMPTY(g)  Defines whether the geospatial object is an empty geometry. See Examples for an example of usage.  
ST_ISSIMPLE(g) 
Defines whether a geospatial object is simple:


ST_OVERLAPS(g,g)  Defines whether two geospatial objects overlap. This is the case if the objects are not identical, their intersection is not empty and has the same dimension as the two objects.  
ST_SETSRID(g,srid)  Sets the SRID for a geometry object (the coordinate system, see EXA_SPATIAL_REF_SYS for more information)  
ST_SYMDIFFERENCE(g,g)  Symmetric difference set of two geospatial objects  
ST_TOUCHES(g,g)  Defines whether two geospatial objects touch each other. This is the case if the intersection is not empty and is only located on the boundaries of the objects (see ST_BOUNDARY for more information)  
ST_TRANSFORM(g,srid)  Converts a geospatial object into the given reference coordinate system (see EXA_SPATIAL_REF_SYS for more information)  
ST_UNION(g,g)  Union set of two geospatial objects  
ST_UNION(g)  Union set of two geospatial objects (aggregated)  
ST_WITHIN(g,g)  Defines whether the first object is fully contained by the second one (opposite of ST_CONTAINS) 
When converting between GEOMETRY types and VARCHAR/CHAR data types, the maximum significant digits used when casting is defined with the ST_MAX_DECIMAL_DIGITS parameter and can be changed using the ALTER SYSTEM or ALTER SESSION statements.
Examples
// This is an example of how ST_ISEMPTY can be used to list empty objects:
CREATE TABLE t1 (id INTEGER, geo GEOMETRY(4326));
INSERT INTO t1 VALUES (1, 'POINT (13.36963 52.52493)'),(2, 'POINT EMPTY'), (3, 'POINT (0.1233 51.5309)');
SELECT id, ST_ISEMPTY(geo) Empty_Geometry from t1;
// Results:
ID EMPTY_GEOMETRY
 
1 false
2 true
3 false