AsShape utilise un objet de type géométrie en entrée et renvoie l'enveloppe convexe correspondante.
Syntaxe
db2gse.ST_ConvexHull(g db2gse.ST_Geometry)
Type de retour
db2gse.ST_Geometry
Exemples
L'exemple ci-après crée la table CONVEXHULL_TEST qui comporte deux colonnes : GEOTYPE et G1. La colonne GEOTYPE, type de données varchar(20), permet d'enregistrer le nom de la sous-classe de la géométrie stockée dans la colonne G1, définie en tant que géométrie.
CREATE TABLE CONVEXHULL_TEST (geotype varchar(20), g1 db2gse.ST_Geometry)
Chaque instruction INSERT insère une géométrie de chaque type de sous-classe dans la table CONVEXHULL_TEST.
INSERT INTO CONVEXHULL_TEST VALUES('Point', db2gse.ST_PointFromText('point (10.02 20.01)', db2gse.coordref()..srid(0))) INSERT INTO CONVEXHULL_TEST VALUES('Linestring', db2gse.ST_LineFromText('linestring (10.02 20.01,10.32 23.98, 11.92 25.64)', db2gse.coordref()..srid(0))) INSERT INTO CONVEXHULL_TEST VALUES('Polygon', db2gse.ST_PolyFromText('polygon ((10.02 20.01,11.92 35.64,25.02 34.15, 19.15 33.94,10.02 20.01))', db2gse.coordref()..srid(0))) INSERT INTO CONVEXHULL_TEST VALUES('Multipoint', db2gse.ST_MPointFromText('multipoint (10.02 20.01,10.32 23.98, 11.92 25.64)', db2gse.coordref()..srid(0))) INSERT INTO CONVEXHULL_TEST VALUES('Multilinestring', db2gse.ST_MLineFromText('multilinestring ((10.02 20.01,10.32 23.98, 11.92 25.64),(9.55 23.75,15.36 30.11))', db2gse.coordref()..srid(0))) INSERT INTO CONVEXHULL_TEST VALUES('Multipolygon', db2gse.ST_MPolyFromText('multipolygon (((10.02 20.01,11.92 35.64, 25.02 34.15, 19.15 33.94,10.02 20.01)), ((51.71 21.73,73.36 27.04,71.52 32.87, 52.43 31.90,51.71 21.73)))', db2gse.coordref()..srid(0)))
L'instruction SELECT ci-après affiche le nom de sous-classe stocké dans la colonne GEOTYPE et l'enveloppe convexe. L'enveloppe convexe générée par la fonction ST_ConvexHull est convertie en texte par la fonction ST_AsText. Elle est ensuite transtypée en données de varchar(256) car la sortie par défaut de la fonction ST_AsText consiste en des données de type varchar(4000).
SELECT GEOTYPE, CAST(db2gse.ST_AsText(db2gse.ST_ConvexHull(G1))) as varchar(256) "The convexhull" FROM CONVEXHULL_TEST