Changeset 19 for trunk/workshop-foss4g/simple_sql.rst
- Timestamp:
- 23/09/2011 15:36:21 (13 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/workshop-foss4g/simple_sql.rst
r1 r19 1 1 .. _simple_sql: 2 2 3 Section 6: Simple SQL 4 ===================== 3 Partie 6 : requêtes SQL simples 4 =============================== 5 5 6 :term:`SQL`, or "Structured Query Language", is a means of asking questions of, and updating data in, relational databases. You have already seen SQL when we created our first database. Recall:6 :term:`SQL`, pour "Structured Query Language", définit comment interroger et mettre des données dans une base. Vous vez déjà du SQL lorsque nous avons notre premiÚre base de données. Rappel: 7 7 8 8 .. code-block:: sql … … 10 10 SELECT postgis_full_version(); 11 11 12 But that was a question about the database. Now that we've loaded data into our database, let's use SQL to ask questions of the data! For example,12 Mais ici c'était une question à propose de la base de données. Maintenant que nous avons carger des données dans notre base, essayons d'utiliser SQL pour interroger les données ! Par exemple, 13 13 14 " What are the names of all the neighborhoods in New York City?"14 "Quel sont les noms des quartier de la ville de New York ?" 15 15 16 O pen up the SQL query window in pgAdmin by clicking the SQL button16 Ouvrez une fenêtre SQL depuis pgAdmin en cliquant sur le bouton SQL 17 17 18 18 .. image:: ./screenshots/pgadmin_05.png 19 19 20 then enter the following query in to the query window 20 Puis saisissez la requête suivante dans la fenêtre 21 21 22 22 .. code-block:: sql … … 24 24 SELECT name FROM nyc_neighborhoods; 25 25 26 and click the **Execute Query** button (the green triangle).26 et cliquez sur le bouton **Execute Query** (le triangle vert). 27 27 28 28 .. image:: ./screenshots/pgadmin_08.png 29 29 30 The query will run for a few (mili)seconds and return the 129 results.30 La requête s'exécutera pendant quelques (mili)secondes et retournera 129 résultats. 31 31 32 32 .. image:: ./screenshots/pgadmin_09.png 33 33 34 But what exactly happened here? To understand, let's begin with the four "verbs" of SQL, 34 Mais que c'est-il exactement passé ici ? Pour le comprendre, commençons par présenter les quatre type de requêtes du SQL : 35 35 36 * ``SELECT``, ret urns rows in response to a query37 * ``INSERT``, a dds new rows to atable38 * ``UPDATE``, alters existing rows in atable39 * ``DELETE``, removes rows from atable36 * ``SELECT``, retourne des lignes en réponse à une requête 37 * ``INSERT``, ajoute des lignes dans une table 38 * ``UPDATE``, modifit des lignes existantes d'une table 39 * ``DELETE``, supprimer des lignes d'une table 40 40 41 We will be working almost exclusively with ``SELECT`` in order to ask questions of tables using spatial functions.41 Nous travaillerons principalement avec des requêtes de type ``SELECT``afin d'interroger les tables en utilisant des fonctions spatiales. 42 42 43 SELECT queries 44 -------------- 43 Requête de type SELECT 44 ---------------------- 45 45 46 A select query is generally of the form:46 Une requête de type Select est généralement de la forme : 47 47 48 SELECT some_columns FROM some_data_source WHERE some_condition;48 SELECT colonnes FROM données WHERE conditions; 49 49 50 50 .. note:: 51 51 52 For a synopsis of all ``SELECT`` parameters, see the PostgresSQL `documentation<http://www.postgresql.org/docs/8.1/interactive/sql-select.html>`_.52 Pour une description exhaustive des paramÚtres possible d'une requête ``SELECT``, consultez la `documentaton de PostgresSQL <http://www.postgresql.org/docs/8.1/interactive/sql-select.html>`_. 53 53 54 The ``some_columns`` are either column names or functions of column values. The ``some_data_source`` is either a single table, or a composite table created by joining two tables on a key or condition. The ``some_condition`` is a filter that restricts the number of rows to be returned.55 54 56 "What are the names of all the neighborhoods in Brooklyn?" 55 Les ``colonnes`` sont soit des noms de colonnes soit des fonctions utilisant les valeurs des colonnes. Les ``données`` sont soit une table seule, ou plusieures tables reliés ensemble en réalisant une jointure sur une clef ou une autre condition. Les ``conditions`` représentent le filtre qui restreint le nombre de lignes a retourner. 57 56 58 We return to our ``nyc_neighborhoods`` table with a filter in hand. The table contains all the neighborhoods in New York, but we only want the ones in Brooklyn. 57 "Quel sont les noms des quartier de Brooklyn ?" 58 59 Nous retournons à notre table ``nyc_neighborhoods`` avec le filtre en main. La table contient tout les quartiers de New Yorl et nous ne voulons que ceux de Brooklyn. 59 60 60 61 .. code-block:: sql … … 64 65 WHERE boroname = 'Brooklyn'; 65 66 66 The query will run for even fewer (mili)seconds and return the 23 results.67 La requête prendra encore que quelque (mili)secondes et retournera les 23 éléments résultants. 67 68 68 Sometimes we will need to apply a function to the results of our query. For example,69 Parfois nous aurons besoin d'appliquer des fonctions sur le résultats d'une de nos requête. Par exemple, 69 70 70 " What is the number of letters in the names of all the neighborhoods in Brooklyn?"71 "Quel est le nombre de lettres dans les noms des quarties de Brooklyn ?" 71 72 72 Fortunately, PostgreSQL has a string length function,:command:`char_length(string)`.73 Heureusement PostgreSQL fournit une fonction calculant la langueur d'une chaîne de caractÚres : :command:`char_length(string)`. 73 74 74 75 .. code-block:: sql … … 78 79 WHERE boroname = 'Brooklyn'; 79 80 80 Often, we are less interested in the individual rows than in a statistic that applies to all of them. So knowing the lengths of the neighborhood names might be less interesting than knowing the average length of the names. Functions that take in multiple rows and return a single result are called "aggregate" functions. 81 Bien souvent nous sommes moins interressé par une ligne particuliÚre mais plus par un calcul statistique sur l'ensemble résultant. Donc connaitre la longueur des noms de quartiers serait moins interressant que de calculer la moyenne des ces longueurs. Les fonctions qui renvoit un résultat unique en utilisant un ensemble de valeurs sont appelée des "fonctions d'aggrégations". 81 82 82 PostgreSQL has a series of built-in aggregate functions, including the general purpose :command:`avg()` for average values and :command:`stddev()` for standard deviations.83 PostgreSQL fournit un ensemble de fonctions d'aggrégations, parmis lesquelles :command:`avg()` pour calculer la moyenne, and :command:`stddev()` pour l'écart type. 83 84 84 " What is the average number of letters and standard deviation of number of letters in the names of all the neighborhoods in Brooklyn?"85 "Quel est le nombre moyen et l'écart type du nombre de lettre dans le noms des quartier de Brooklyn ?" 85 86 86 87 .. code-block:: sql … … 96 97 11.7391304347826087 | 3.9105613559407395 97 98 98 The aggregate functions in our last example were applied to every row in the result set. What if we want the summaries to be carried out over smaller groups within the overall result set? For that we add a ``GROUP BY`` clause. Aggregate functions often need an added ``GROUP BY`` statement to group the result-set by one or more columns. 99 Les fonctions d'agrégation dans notre dernier exemple sont appliquées à chaque ligne de l'ensemble des résultats. Comment faire si nous voulons rassembler des données ? Pour cela nous utilisons la clause ``GROUP BY``. Les fonctions d'agrégation ont souvent besoin d'une clause ``GROUP BY`` pour regrouper les éléments en utilisant une ou plusieures colonnes. 99 100 100 " What is the average number of letters in the names of all the neighborhoods in New York City, reported by borough?"101 "Quel est la moyenne des les noms de quartier de New York, renvoyer par quartiers ?" 101 102 102 103 .. code-block:: sql … … 106 107 GROUP BY boroname; 107 108 108 We include the ``boroname`` column in the output result so we can determine which statistic applies to which borough. In an aggregate query, you can only output columns that are either (a) members of the grouping clause or (b) aggregate functions. 109 110 Nous ajoutons la colonne ``boroname`` dans le résultat afin de pouvoir déterminer quelle valeur statistique s'applique à quel quartier. Dans une requête agrégée, vous pouvez seulement retourner les colonnes qui sont (a) membre de la clause de regroupement ou (b) des fonctions d'agrégation. 109 111 110 112 :: … … 118 120 Staten Island | 12.2916666666666667 | 5.2043390480959474 119 121 120 Function List 121 ------------- 122 Liste de fonctions 123 ------------------ 122 124 123 `avg(expression) <http://www.postgresql.org/docs/current/static/functions-aggregate.html#FUNCTIONS-AGGREGATE-TABLE>`_: PostgreSQL aggregate function that returns the average value of a numeric column.125 `avg(expression) <http://www.postgresql.org/docs/current/static/functions-aggregate.html#FUNCTIONS-AGGREGATE-TABLE>`_: fonction d'agrégation de PostgreSQL qui retourne la valeur moyenne d'une colonne. 124 126 125 `char_length(string) <http://www.postgresql.org/docs/current/static/functions-string.html>`_: PostgreSQL string function that returns the number of character in a string.127 `char_length(string) <http://www.postgresql.org/docs/current/static/functions-string.html>`_: fonction s'applicant aux chaînes de caractÚre de PostgreSQL qui retourne le nombre de lettre dans une chaîne. 126 128 127 `stddev(expression) <http://www.postgresql.org/docs/current/static/functions-aggregate.html#FUNCTIONS-AGGREGATE-STATISTICS-TABLE>`_: PostgreSQL aggregate function that returns the standard deviation of input values.129 `stddev(expression) <http://www.postgresql.org/docs/current/static/functions-aggregate.html#FUNCTIONS-AGGREGATE-STATISTICS-TABLE>`_: fonction d'aggrégation de PostgreSQL qui retourne l'écart type d'un ensemble de valeurs. 128 130 129 131
Note: See TracChangeset
for help on using the changeset viewer.