Bienvenue sur PostGIS.fr

Bienvenue sur PostGIS.fr , le site de la communauté des utilisateurs francophones de PostGIS.

PostGIS ajoute le support d'objets géographique à la base de données PostgreSQL. En effet, PostGIS "spatialise" le serverur PostgreSQL, ce qui permet de l'utiliser comme une base de données SIG.

Maintenu à jour, en fonction de nos disponibilités et des diverses sorties des outils que nous testons, nous vous proposons l'ensemble de nos travaux publiés en langue française.

source: trunk/workshop-foss4g/geometries.rst @ 19

Revision 19, 19.4 KB checked in by djay, 13 years ago (diff)

Ajouter quelques traductions.

RevLine 
[1]1.. _geometries:
2
[19]3Partie 8 : les géometries
[1]4=====================
5
6Introduction
7------------
8
[19]9Dans :ref:`une partie précédente<loading_data>` nous avons charger différentes données. Avant de commencer à jouer avec, commençons par regarder quelques exemples simples. Depuis pgAdmin, choisissez encore la base de donnée **nyc** et ouvrez l'outils de requêtage SQL. Copiez cette exemple de code SQL (aprÚs avoir supprimer le contenu présent défaut si nécessaire) puis exécutez-le.
[1]10
11.. code-block:: sql
12
13  CREATE TABLE geometries (name varchar, geom geometry);
14 
15  INSERT INTO geometries VALUES
16    ('Point', 'POINT(0 0)'),
17    ('Linestring', 'LINESTRING(0 0, 1 1, 2 1, 2 2)'),
18    ('Polygon', 'POLYGON((0 0, 1 0, 1 1, 0 1, 0 0))'),
19    ('PolygonWithHole', 'POLYGON((0 0, 10 0, 10 10, 0 10, 0 0),(1 1, 1 2, 2 2, 2 1, 1 1))'),
20    ('Collection', 'GEOMETRYCOLLECTION(POINT(2 0),POLYGON((0 0, 1 0, 1 1, 0 1, 0 0)))');
21   
22  SELECT Populate_Geometry_Columns();
23 
24  SELECT name, ST_AsText(geom) FROM geometries;
25
26.. image:: ./geometries/start01.png
27
[19]28L'exemple ci-dessus créé une table (**geometries**) puis y insert cinq géométries : un point, une ligne, un polygone, un polygone avec un trou, et une collection. Au final, les lignes insérées sont sélectionnées et affichées dans le tableau de sortie.
[1]29
[19]30Les tables de métadonnées
31-------------------------
[1]32
[19]33Dans le respect de la spécification Simple Features for SQL (:term:`SFSQL`), PostGIS fournit deux tables pour récupérer et s'informer sur les types de géométries disponibles dans une base de données spécifique.
[1]34
[19]35* La premiÚre table, ``spatial_ref_sys``, définit tout les systÚme de projection connu de la base de données et sera décrite plus en détals plus tard. 
36* La seconde table, ``geometry_columns``, fournit une liste de toutes les "entités" (définit comme un objet avec un attribut géométrique) et les détails de base relatives à ces entités.
[1]37
38.. image:: ./geometries/table01.png
39
[19]40Dans l'exemple founit en introduction, la fonction :command:`Populate_Geometry_Columns()` détecte toute les colonnes de la base de données qui contiennent des géométries et met à jour la table ``geometry_columns`` pour y inclure leurs références.
[1]41
[19]42Regardons maintenant table ``geometry_columns`` de notre base de données. Copiez cette commande dans la fenêtre de requêtage :
[1]43
[19]44
[1]45.. code-block:: sql
46
47  SELECT * FROM geometry_columns;
48
49.. image:: ./geometries/start08.png
50
[19]51* ``f_table_catalog``, ``f_table_schema``, et ``f_table_name`` fournissent le nom complet de la table contenant une géométrie donnée. Étant donné que PostgreSQL n'utilise pas de catalogues, ``f_table_catalog`` est toujouts vide. 
52* ``f_geometry_column`` est le nom de la colonne qui contient la géométrie -- pour les tables ayant plusieurs colonnes géométriques, il y a un enregistrement dans cette table pour chacune.
53* ``coord_dimension`` et ``srid`` définissent respectivement la dimension de la géométrie (en 2-, 3- or 4-dimensions) et le systÚme de références spatiales qui fait référence à la table ``spatial_ref_sys``
54* La colonne ``type`` définit le type de géométrie comme décrit plus tÃŽt, nous avons déjà vu les points et les lignes. 
[1]55
[19]56En interrogeant cette table, les clients SIG et les libraires peuvent déterminer quoi attendre lors de la récupration des données et peuvent réaliser les opération de reprojection, transformation ou rendu sans avoir a inspecter chaque géométrie.
[1]57
[19]58Réprésenter des objets du mode réel
59-----------------------------------
[1]60
[19]61La spécification Simple Features for SQL (:term:`SFSQL`), le standard ayant guidé le développement de PostGIS, définit comment les objets du monde réel doivent être représentés. En considérant une forme continue à une seule résolution fixe, nous obtenu un piÚtre représentation des objets. SFSQL considÚre uniquement les représentations en 2 dimensions. PostGIS a étendu cela en ajoutant les représentation en 3 et 4 dimensions, plus récemment la spécification SQL-Multimedia Part 3 (:term:`SQL/MM`) a officiellement définit sa propre représenation.
[1]62
[19]63Notre table exemple contient différents types de géométries Nous pouvons récupérer les informations de chaque objets en utilisant les fonctions qui lisent les métadonnées de la géométrie.
[1]64
[19]65 * :command:`ST_GeometryType(geometry)` retourne le type de la géométrie
66 * :command:`ST_NDims(geometry)` retourne le nombre de dimension d'une géométrie
67 * :command:`ST_SRID(geometry)` retourne l'identifiant de référence spatiale de la géométrie
[1]68
69.. code-block:: sql
70
71  SELECT name, ST_GeometryType(geom), ST_NDims(geom), ST_SRID(geom)
72    FROM geometries;
73
74::
75
76       name       |    st_geometrytype    | st_ndims | st_srid
77 -----------------+-----------------------+----------+---------
78  Point           | ST_Point              |        2 |      -1
79  Polygon         | ST_Polygon            |        2 |      -1
80  PolygonWithHole | ST_Polygon            |        2 |      -1
81  Collection      | ST_GeometryCollection |        2 |      -1
82  Linestring      | ST_LineString         |        2 |      -1
83
84
85
[19]86Les points
87~~~~~~~~~~~
[1]88
89.. image:: ./introduction/points.png
90   :align: center
91
[19]92Un **point** spatiale représente une localisation unique sur la Terre. Ce point est représenté par une seule coordonnée (incluant soit 2, 3 ou 4 dimensions). Les points sont utilisés pour représenter des objets lorsque le détails exact du contour n'est pas important à une échelle donnée. Par exemple, les villes sur une carte du monde pourraient être décrite sous la forme de points alors qu'une carte régionale utiliserait une représentation polygonale des villes.
[1]93
94.. code-block:: sql
95
96  SELECT ST_AsText(geom)
97    FROM geometries
98    WHERE name = 'Point';
99
100::
101
102  POINT(0 0)
103
[19]104Ceraints des fonctions spécifiques pour travailler avec les points sont :
[1]105
[19]106 * :command:`ST_X(geometry)` retourne la composante X
107 * :command:`ST_Y(geometry)` retourne la composante Y
[1]108
[19]109Donc, nous pouvons lire les coordonnées d'un point de la maniÚre suivante :
[1]110
111.. code-block:: sql
112
113  SELECT ST_X(geom), ST_Y(geom)
114    FROM geometries
115    WHERE name = 'Point';
116
[19]117La table des stations de métros de la ville de New York  (``nyc_subway_stations``) est un ensemble de données représenté sous la forme de points. La requête SQL suivante reverra la géométrie associée à un point (dans la colonne :command:`ST_AsText`).
[1]118
119.. code-block:: sql
120
121  SELECT name, ST_AsText(the_geom)
122    FROM nyc_subway_stations
123    LIMIT 1;
124
125
[19]126Les lignes
[1]127~~~~~~~~~~~
128
129.. image:: ./introduction/lines.png
130   :align: center
131
[19]132Une **ligne** est un chemin entre plusieurs points. Elle prend la forme d'un tableay ordonné de deux (ou plus) points. Les routes et les riviÚres sont tipyquement représenté sous la forme de lignes. Une ligne est dire **fermée** si elle commence et se fini en un même point. Elle est dite **simple** si elle ne se coupe pas ni se touche elle-même (sauf à ses extrémités si elle est fermée). Une ligne peut être à la fois **fermée** et **simple**.
[1]133
[19]134Le réseau des rues de New York (``nyc_streets``) a été chargé plus tÎt. Cet ensemble de données contient les détails comme le nom et le type. Une rue du monde réelle pourrait être constituée de plusieurs lignes, chacune représentant une file de la avec différents attributs.
[1]135
[19]136La requête SQL suivante retourne la géométrie associée à une ligne (dans la colonne :command:`ST_AsText`) :
[1]137
138.. code-block:: sql
139
140  SELECT ST_AsText(geom)
141    FROM geometries
142    WHERE name = 'Linestring';
143 
144::
145
146  LINESTRING(0 0, 1 1, 2 1, 2 2)
147
[19]148Les fonctions spatiales permettant de travailler avec les lignes sont les suivantes :
[1]149
[19]150 * :command:`ST_Length(geometry)` retourne la longueur d'une ligne
151 * :command:`ST_StartPoint(geometry)` retourne le premier point d'une ligne
152 * :command:`ST_EndPoint(geometry)` retourne le denier point d'une ligne
153 * :command:`ST_NPoints(geometry)` retourne le nombre de points dans une ligne
[1]154
[19]155Donc, la longueur de notre ligne est :
[1]156
157.. code-block:: sql
158
159  SELECT ST_Length(geom)
160    FROM geometries
161    WHERE name = 'Linestring';
162
163::
164
165  3.41421356237309
166
167
[19]168Les polygones
169~~~~~~~~~~~~~~
[1]170
171.. image:: ./introduction/polygons.png
172  :align: center
173
[19]174Un polygone est représenté comme une zone. Le contour externe du polygone est représenté par une ligne simple et fermée. Les trous sont représenté de la même maniÚre.
[1]175
[19]176Les polygones sont utiliser pour représenter les objets dont les tailles et la forme sont importants. Les limites de villes, les parks, les batiments ou les cours d'eau sont habituellement représenté par des polygones lorsque l'échelle est suffisament élevée pour voir distinguer leurs zones. Les routes et les riviÚres peuvent parfois être représenté comme des polygones.
[1]177
[19]178La requête SQL suivante retournera la géométrie associée à un polygon (dans la colonne :command:`ST_AsText`).
[1]179
180.. code-block:: sql
181
182  SELECT ST_AsText(geom)
183    FROM geometries
184    WHERE name LIKE 'Polygon%';
185
186.. note::
187
[19]188  PlutÃŽt que d'utiliser le signe ``=`` dans notre clause ``WHERE``, nous avons utilisé l'opérateur ``LIKE`` pour pouvoir définir notre comparaison. Vous auriez sans doute voulu utiliser le symbole ``*`` pour exprimer "n'importe quelle valeur" mais en SQL vous devez utiliser : ``%`` et l'opérateur ``LIKE`` pour informer le systÚme que cette comparaison doit être possible.
[1]189
190::
191
192 POLYGON((0 0, 1 0, 1 1, 0 1, 0 0))
193 POLYGON((0 0, 10 0, 10 10, 0 10, 0 0),(1 1, 1 2, 2 2, 2 1, 1 1))
194
[19]195Le premier polygon a seulement une ligne. Le second a un "trou". La plupart des systÚmes de rendu graphique supportent le concept de "polygone", mais les systÚme SIG sont les seuls a accepter que les polygones puisse contenir des trous.
[1]196
197.. image:: ./screenshots/polygons.png
198
[19]199Certaines des fonctions spatiales spécifique de traitement des polygones sont :
[1]200
[19]201 * :command:`ST_Area(geometry)` retourne l'aire de polygones
202 * :command:`ST_NRings(geometry)` retourne le nombre de contour (habituellement 1, plus lorsqu'il y a des trous)
203 * :command:`ST_ExteriorRing(geometry)` rentourne le contour extérieur
204 * :command:`ST_InteriorRingN(geometry,n)` retourne le contour intérieur numéro n
205 * :command:`ST_Perimeter(geometry)` retourne la longueur de tout les contours
[1]206
[19]207Nous pouvons calculer l'aire de nos polygones en utilisant la fonction area :
[1]208
209.. code-block:: sql
210
211  SELECT name, ST_Area(geom)
212    FROM geometries
213    WHERE name LIKE 'Polygon%';
214
215::
216
217  Polygon            1
218  PolygonWithHole    99
219
[19]220Remarquez que le polygone contenant un trou a une aire égale à l'aire du contour externe (un carré de 10 sur 10) moins l'aire du trou (un carré de 1 sur 1).
[1]221
[19]222Les collections
223~~~~~~~~~~~~~~~~
[1]224
[19]225Il y a quatre types de collections, qui regroupe ensembles plusieurs géométries simples.
[1]226
[19]227 * **MultiPoint**, une collection de points
228 * **MultiLineString**, une collection de lignes
229 * **MultiPolygon**, une collection de polygones
230 * **GeometryCollection**, une collections hétérogÚne de n'importe quelle géométrie (dont d'autre collections)
[1]231
[19]232Les collections sont un concept présents dans les logiciels SIG  plus que dans les application de rendu graphique générique. Elles sont utiles pour directement modeler  les objets du monde réel comme des objet spatiaux. Par exemple, comment modéliser une parcelle qui é coupée par un chemin ? Comme un **MultiPolygon**, ayant une partie de chaque coté du chemin.
[1]233
234.. image:: ./screenshots/collection2.png
235
[19]236Notre collection exemple contient un polygon et un point :
[1]237
238.. code-block:: sql
239
240  SELECT name, ST_AsText(geom)
241    FROM geometries
242    WHERE name = 'Collection';
243
244::
245
246  GEOMETRYCOLLECTION(POINT(2 0),POLYGON((0 0, 1 0, 1 1, 0 1, 0 0)))
247
248.. image:: ./screenshots/collection.png
249
[19]250Certaines des fonctions spatiales spécifiques à la manipulation des collections sont :
[1]251
[19]252 * :command:`ST_NumGeometries(geometry)` retourne le nombre de composantes d'une collection
253 * :command:`ST_GeometryN(geometry,n)` retourne une composante spécifique
254 * :command:`ST_Area(geometry)` retourne l'aire totale des composantes de types polygones
255 * :command:`ST_Length(geometry)` retourne la longueur totale des composantes de types lignes
[1]256
257
258
[19]259Entré / Sortie des géométries
260-----------------------------
[1]261
262Within the database, geometries are stored on disk in a format only used by the PostGIS program. In order for external programs to insert and retrieve useful geometries, they need to be converted into a format that other applications can understand. Fortunately, PostGIS supports emitting and consuming geometries in a large number of formats:
263
264 * Well-known text (:term:`WKT`)
265 
266   * :command:`ST_GeomFromText(text)` returns ``geometry``
267   * :command:`ST_AsText(geometry)` returns ``text``
268   * :command:`ST_AsEWKT(geometry)` returns ``text``
269   
270 * Well-known binary (:term:`WKB`)
271 
272   * :command:`ST_GeomFromWKB(bytea)` returns ``geometry``
273   * :command:`ST_AsBinary(geometry)` returns ``bytea``
274   * :command:`ST_AsEWKB(geometry)` returns ``bytea``
275   
276 * Geographic Mark-up Language (:term:`GML`)
277 
278   * :command:`ST_GeomFromGML(text)` returns ``geometry``
279   * :command:`ST_AsGML(geometry)` returns ``text``
280   
281 * Keyhole Mark-up Language (:term:`KML`)
282 
283   * :command:`ST_GeomFromKML(text)` returns ``geometry``
284   * :command:`ST_AsKML(geometry)` returns ``text``
285   
286 * :term:`GeoJSON`
287 
288   * :command:`ST_AsGeoJSON(geometry)` returns ``text``
289   
290 * Scalable Vector Graphics (:term:`SVG`)
291 
292   * :command:`ST_AsSVG(geometry)` returns ``text``
293 
294The following SQL query shows an example of :term:`WKB` representation (the call to :command:`encode()` is required to convert the binary output into an ASCII form for printing):
295
296.. code-block:: sql
297
298  SELECT encode(
299    ST_AsBinary(ST_GeometryFromText('LINESTRING(0 0 0,1 0 0,1 1 2)')),
300    'hex');
301
302.. image:: ./geometries/represent-04.png
303
304For the purposes of this workshop we will continue to use WKT to ensure you can read and understand the geometries we're viewing.  However, most actual processes, such as viewing data in a GIS application, transferring data to a web service, or processing data remotely, WKB is the format of choice. 
305
306Since WKT and WKB were defined in the  :term:`SFSQL` specification, they do not handle 3- or 4-dimensional geometries.  For these cases PostGIS has defined the Extended Well Known Text (EWKT) and Extended Well Known Binary (EWKB) formats.  These provide the same formatting capabilities of WKT and WKB with the added dimensionality.
307
308Here is an example of a 3D linestring in WKT:
309
310.. code-block:: sql
311
312  SELECT ST_AsEWKT(ST_GeometryFromText('LINESTRING(0 0 0,1 0 0,1 1 2)'));
313
314.. image:: ./geometries/represent-05.png
315
316.. code-block:: sql
317
318  SELECT encode(ST_AsEWKB(ST_GeometryFromText(
319      'LINESTRING(0 0 0,1 0 0,1 1 2)')), 'hex');
320
321.. image:: ./geometries/represent-06.png
322
323In addition to emitters for the various forms (WKT, WKB, GML, KML, JSON, SVG), PostGIS also has consumers for four (WKT, WKB, GML, KML). Most applications use the WKT or WKB geometry creation functions, but the others work too. Here's an example that consumes GML and output JSON:
324
325.. code-block:: sql
326
327  SELECT ST_AsGeoJSON(ST_GeomFromGML('<gml:Point><gml:coordinates>1,1</gml:coordinates></gml:Point>'));
328
329.. image:: ./geometries/represent-07.png
330
331Function List
332-------------
333
334`Populate_Geometry_Columns <http://postgis.org/docs/Populate_Geometry_Columns.html>`_: Ensures geometry columns have appropriate spatial constraints and exist in the geometry_columns table..
335
336`ST_Area <http://postgis.org/docs/ST_Area.html>`_: Returns the area of the surface if it is a polygon or multi-polygon. For "geometry" type area is in SRID units. For "geography" area is in square meters.
337
338`ST_AsText <http://postgis.org/docs/ST_AsText.html>`_: Returns the Well-Known Text (WKT) representation of the geometry/geography without SRID metadata.
339
340`ST_AsBinary <http://postgis.org/docs/ST_AsBinary.html>`_: Returns the Well-Known Binary (WKB) representation of the geometry/geography without SRID meta data.
341
342`ST_EndPoint <http://postgis.org/docs/ST_EndPoint.html>`_: Returns the last point of a LINESTRING geometry as a POINT.
343
344`ST_AsEWKB <http://postgis.org/docs/ST_AsEWKB.html>`_: Returns the Well-Known Binary (WKB) representation of the geometry with SRID meta data.
345
346`ST_AsEWKT <http://postgis.org/docs/ST_AsEWKT.html>`_: Returns the Well-Known Text (WKT) representation of the geometry with SRID meta data.
347
348`ST_AsGeoJSON <http://postgis.org/docs/ST_AsGeoJSON.html>`_: Returns the geometry as a GeoJSON element.
349
350`ST_AsGML <http://postgis.org/docs/ST_AsGML.html>`_: Returns the geometry as a GML version 2 or 3 element.
351
352`ST_AsKML <http://postgis.org/docs/ST_AsKML.html>`_: Returns the geometry as a KML element. Several variants. Default version=2, default precision=15.
353
354`ST_AsSVG <http://postgis.org/docs/ST_AsSVG.html>`_: Returns a Geometry in SVG path data given a geometry or geography object.
355
356`ST_ExteriorRing <http://postgis.org/docs/ST_ExteriorRing.html>`_: Returns a line string representing the exterior ring of the POLYGON geometry. Return NULL if the geometry is not a polygon. Will not work with MULTIPOLYGON
357
358`ST_GeometryN <http://postgis.org/docs/ST_GeometryN.html>`_: Returns the 1-based Nth geometry if the geometry is a GEOMETRYCOLLECTION, MULTIPOINT, MULTILINESTRING, MULTICURVE or MULTIPOLYGON. Otherwise, return NULL.
359
360`ST_GeomFromGML <http://postgis.org/docs/ST_GeomFromGML.html>`_: Takes as input GML representation of geometry and outputs a PostGIS geometry object.
361
362`ST_GeomFromKML <http://postgis.org/docs/ST_GeomFromKML.html>`_: Takes as input KML representation of geometry and outputs a PostGIS geometry object
363
364`ST_GeomFromText <http://postgis.org/docs/ST_GeomFromText.html>`_: Returns a specified ST_Geometry value from Well-Known Text representation (WKT).
365
366`ST_GeomFromWKB <http://postgis.org/docs/ST_GeomFromWKB.html>`_: Creates a geometry instance from a Well-Known Binary geometry representation (WKB) and optional SRID.
367
368`ST_GeometryType <http://postgis.org/docs/ST_GeometryType.html>`_: Returns the geometry type of the ST_Geometry value.
369
370`ST_InteriorRingN <http://postgis.org/docs/ST_InteriorRingN.html>`_: Returns the Nth interior linestring ring of the polygon geometry. Return NULL if the geometry is not a polygon or the given N is out of range.
371
372`ST_Length <http://postgis.org/docs/ST_Length.html>`_: Returns the 2d length of the geometry if it is a linestring or multilinestring. geometry are in units of spatial reference and geography are in meters (default spheroid)
373
374`ST_NDims <http://postgis.org/docs/ST_NDims.html>`_: Returns coordinate dimension of the geometry as a small int. Values are: 2,3 or 4.
375
376`ST_NPoints <http://postgis.org/docs/ST_NPoints.html>`_: Returns the number of points (vertexes) in a geometry.
377
378`ST_NRings <http://postgis.org/docs/ST_NRings.html>`_: If the geometry is a polygon or multi-polygon returns the number of rings.
379
380`ST_NumGeometries <http://postgis.org/docs/ST_NumGeometries.html>`_: If geometry is a GEOMETRYCOLLECTION (or MULTI*) returns the number of geometries, otherwise return NULL.
381
382`ST_Perimeter <http://postgis.org/docs/ST_Perimeter.html>`_: Returns the length measurement of the boundary of an ST_Surface or ST_MultiSurface value. (Polygon, Multipolygon)
383
384`ST_SRID <http://postgis.org/docs/ST_SRID.html>`_: Returns the spatial reference identifier for the ST_Geometry as defined in spatial_ref_sys table.
385
386`ST_StartPoint <http://postgis.org/docs/ST_StartPoint.html>`_: Returns the first point of a LINESTRING geometry as a POINT.
387
388`ST_X <http://postgis.org/docs/ST_X.html>`_: Returns the X coordinate of the point, or NULL if not available. Input must be a point.
389
390`ST_Y <http://postgis.org/docs/ST_Y.html>`_: Returns the Y coordinate of the point, or NULL if not available. Input must be a point.
391
392
Note: See TracBrowser for help on using the repository browser.