PostgreSQLLa base de données la plus sophistiquée au monde.

Version anglaise

Documentation PostgreSQL 9.4.26

The PostgreSQL Global Development Group


Table des matières

Préface
1. Définition de PostgreSQL
2. Bref historique de PostgreSQL
3. Conventions
4. Pour plus d'informations
5. Lignes de conduite pour les rapports de bogues
I. Tutoriel
1. Démarrage
2. Le langage SQL
3. Fonctionnalités avancées
II. Langage SQL
4. Syntaxe SQL
5. Définition des données
6. Manipulation de données
7. Requêtes
8. Types de données
9. Fonctions et opérateurs
10. Conversion de types
11. Index
12. Recherche plein texte
13. Contrôle d'accès simultané
14. Conseils sur les performances
III. Administration du serveur
15. Procédure d'installation de PostgreSQL du code source
16. Installation à partir du code source sur Windows
17. Configuration du serveur et mise en place
18. Configuration du serveur
19. Authentification du client
20. Rôles de la base de données
21. Administration des bases de données
22. Localisation
23. Planifier les tâches de maintenance
24. Sauvegardes et restaurations
25. Haute disponibilité, répartition de charge et réplication
26. Configuration de la récupération
27. Surveiller l'activité de la base de données
28. Surveiller l'utilisation des disques
29. Fiabilité et journaux de transaction
30. Tests de régression
IV. Interfaces client
31. libpq - Bibliothèque C
32. Objets larges
33. ECPG SQL embarqué en C
34. Schéma d'information
V. Programmation serveur
35. Étendre SQL
36. Déclencheurs (triggers)
37. Déclencheurs (triggers) sur évènement
38. Système de règles
39. Langages de procédures
40. PL/pgSQL - Langage de procédures SQL
41. PL/Tcl - Langage de procédures Tcl
42. PL/Perl - Langage de procédures Perl
43. PL/Python - Langage de procédures Python
44. Interface de programmation serveur
45. Processus en tâche de fond (background worker)
46. Décodage logique (Logical Decoding)
VI. Référence
I. Commandes SQL
II. Applications client de PostgreSQL
III. Applications relatives au serveur PostgreSQL
VII. Internes
47. Présentation des mécanismes internes de PostgreSQL
48. Catalogues système
49. Protocole client/serveur
50. Conventions de codage pour PostgreSQL
51. Support natif des langues
52. Écrire un gestionnaire de langage procédural
53. Écrire un wrapper de données distantes
54. Optimiseur génétique de requêtes (Genetic Query Optimizer)
55. Définition de l'interface des méthodes d'accès aux index
56. Index GiST
57. Index SP-GiST
58. Index GIN
59. Stockage physique de la base de données
60. Interface du moteur, BKI
61. Comment le planificateur utilise les statistiques
VIII. Annexes
A. Codes d'erreurs de PostgreSQL
B. Support de date/heure
C. Mots-clé SQL
D. Conformité SQL
E. Notes de version
F. Modules supplémentaires fournis
G. Programmes supplémentaires fournis
H. Projets externes
I. Dépôt du code source
J. Documentation
K. Acronymes
L. Traduction française
Bibliographie

Liste des tableaux

4.1. Séquences d'échappements avec antislash
4.2. Précédence des opérateurs (en ordre décroissant)
8.1. Types de données
8.2. Types numériques
8.3. Types monétaires
8.4. Types caractère
8.5. Types caractères spéciaux
8.6. Types de données binaires
8.7. Octets littéraux bytea à échapper
8.8. Octets échappés en sortie pour bytea
8.9. Types date et heure
8.10. Saisie de date
8.11. Saisie d'heure
8.12. Saisie des fuseaux horaires
8.13. Saisie de dates/heures spéciales
8.14. Styles d'affichage de date/heure
8.15. Convention de présentation des dates
8.16. Abréviations d'unités d'intervalle ISO 8601
8.17. Saisie d'intervalle
8.18. Exemples de styles d'affichage d'intervalles
8.19. Type de données booléen
8.20. Types géométriques
8.21. Types d'adresses réseau
8.22. Exemples de saisie de types cidr
8.23. Types primitifs JSON et types PostgreSQL™ correspondants
8.24. Types identifiant d'objet
8.25. Pseudo-Types
9.1. Opérateurs de comparaison
9.2. Opérateurs mathématiques
9.3. Fonctions mathématiques
9.4. Fonctions de génération de nombres aléatoires
9.5. Fonctions trigonométriques
9.6. Fonctions et opérateurs SQL pour le type chaîne
9.7. Autres fonctions de chaîne
9.8. Conversions intégrées
9.9. Fonctions et opérateurs SQL pour chaînes binaires
9.10. Autres fonctions sur les chaînes binaires
9.11. Opérateurs sur les chaînes de bits
9.12. Opérateurs de correspondance des expressions rationnelles
9.13. Atomes d'expressions rationnelles
9.14. quantificateur d'expressions rationnelles
9.15. Contraintes des expressions rationnelles
9.16. Échappements de caractère dans les expressions rationnelles
9.17. Échappement de raccourcis de classes dans les expressions rationnelles
9.18. Échappements de contrainte dans les expressions rationnelles
9.19. Rétroréférences dans les expressions rationnelles
9.20. Lettres d'option intégrées à une ERA
9.21. Fonctions de formatage
9.22. Modèles pour le formatage de champs de type date/heure
9.23. Modificateurs de motifs pour le formatage des dates/heures
9.24. Motifs de modèle pour le formatage de valeurs numériques
9.25. Modifications de motifs pour le formatage numérique
9.26. Exemples avec to_char
9.27. Opérateurs date/heure
9.28. Fonctions date/heure
9.29. Variantes AT TIME ZONE
9.30. Fonctions de support enum
9.31. Opérateurs géométriques
9.32. Fonctions géométriques
9.33. Fonctions de conversion de types géométriques
9.34. Opérateurs cidr et inet
9.35. Fonctions cidr et inet
9.36. Fonctions macaddr
9.37. Opérateurs de recherche plein texte
9.38. Fonctions de la recherche plein texte
9.39. Fonctions de débogage de la recherche plein texte
9.40. Opérateurs json et jsonb
9.41. Opérateurs jsonb supplémentaires
9.42. Fonctions de création de données JSON
9.43. Fonctions de traitement du JSON
9.44. Fonctions séquence
9.45. Opérateurs pour les tableaux
9.46. Fonctions pour les tableaux
9.47. Opérateurs pour les types range
9.48. Fonctions range
9.49. Fonctions d'agrégat générales
9.50. Fonctions d'agrégats pour les statistiques
9.51. Fonctions d'agrégat par ensemble trié
9.52. Fonctions d'agrégat par ensemble hypothétique
9.53. Fonctions Window généralistes
9.54. Fonctions de génération de séries
9.55. Fonctions de génération d'indices
9.56. Fonctions d'information de session
9.57. Fonctions de consultation des privilèges d'accès
9.58. Fonctions d'interrogation de visibilité dans les schémas
9.59. Fonctions d'information du catalogue système
9.60. Fonctions d'informations sur les commentaires
9.61. ID de transaction et instantanés
9.62. Composants de l'instantané
9.63. Fonctions agissant sur les paramètres de configuration
9.64. Fonctions d'envoi de signal au serveur
9.65. Fonctions de contrôle de la sauvegarde
9.66. Fonctions d'information sur la restauration
9.67. Fonctions de contrôle de la restauration
9.68. Fonction de synchronisation de snapshot
9.69. Fonctions SQL pour la réplication
9.70. Fonctions de calcul de la taille des objets de la base de données
9.71. Fonctions de récupération de l'emplacement des objets de la base de données
9.72. Fonctions d'accès générique aux fichiers
9.73. Fonctions de verrous consultatifs
12.1. Types de jeton de l'analyseur par défaut
13.1. Niveaux d'isolation standards des transactions SQL
13.2. Modes de verrou conflictuels
13.3. Verrous en conflit au niveau ligne
17.1. Paramètres system v ipc
17.2. Utilisation des fichiers serveur SSL
18.1. Niveaux de sévérité des messages
18.2. Clé d'option courte
22.1. Jeux de caractères de PostgreSQL
22.2. Conversion de jeux de caractères client/serveur
25.1. Matrice de fonctionnalités : haute disponibilité, répartition de charge et réplication
27.1. Vues statistiques standards
27.2. Vue pg_stat_activity
27.3. Vue pg_stat_archiver
27.4. Vue pg_stat_bgwriter
27.5. Vue pg_stat_database
27.6. Vue pg_stat_all_tables
27.7. Vue pg_stat_all_indexes
27.8. Vue pg_statio_all_tables
27.9. Vue pg_statio_all_indexes
27.10. Vue pg_statio_all_sequences
27.11. Vue pg_stat_user_functions
27.12. Vue pg_stat_replication
27.13. Vue pg_stat_database_conflicts
27.14. Fonctions supplémentaires de statistiques
27.15. Fonctions statistiques par processus serveur
27.16. Sondes disponibles pour DTrace
27.17. Types définis utilisés comme paramètres de sonde
31.1. Description des modes SSL
31.2. Utilisation des fichiers SSL libpq/client
32.1. Fonctions SQL pour les Large Objects
33.1. Correspondance Entre les Types PostgreSQL et les Types de Variables C
33.2. Formats d'Entrée Valides pour PGTYPESdate_from_asc
33.3. Formats d'Entrée Valides pour PGTYPESdate_fmt_asc
33.4. Formats d'Entrée Valides pour rdefmtdate
33.5. Formats d'Entrée Valide pour PGTYPEStimestamp_from_asc
34.1. Colonnes de information_schema_catalog_name
34.2. Colonnes de administrable_role_authorizations
34.3. Colonnes de applicable_roles
34.4. Colonnes de attributes
34.5. Colonnes de character_sets
34.6. Colonnes de check_constraint_routine_usage
34.7. Colonnes de check_constraints
34.8. Colonnes de collations
34.9. Colonnes de collation_character_set_applicability
34.10. Colonnes de column_domain_usage
34.11. Colonnes de column_options
34.12. Colonnes de column_privileges
34.13. Colonnes de column_udt_usage
34.14. Colonnes de columns
34.15. Colonnes de constraint_column_usage
34.16. Colonnes de constraint_table_usage
34.17. Colonnes de data_type_privileges
34.18. Colonnes de domain_constraints
34.19. Colonnes de domain_udt_usage
34.20. Colonnes de domains
34.21. Colonnes de element_types
34.22. Colonnes de enabled_roles
34.23. Colonnes de foreign_data_wrapper_options
34.24. Colonnes de foreign_data_wrappers
34.25. Colonnes de foreign_server_options
34.26. Colonnes de foreign_servers
34.27. Colonnes de foreign_table_options
34.28. Colonnes de foreign_tables
34.29. Colonnes de key_column_usage
34.30. Colonnes de parameters
34.31. Colonnes de referential_constraints
34.32. Colonnes de role_column_grants
34.33. Colonnes de role_routine_grants
34.34. Colonnes de role_table_grants
34.35. Colonnes de role_udt_grants
34.36. Colonnes de role_usage_grants
34.37. Colonnes de routine_privileges
34.38. Colonnes de routines
34.39. Colonnes de schemata
34.40. Colonnes de sequences
34.41. Colonnes de sql_features
34.42. Colonnes de sql_implementation_info
34.43. Colonnes de sql_languages
34.44. Colonnes de sql_packages
34.45. Colonnes de sql_parts
34.46. Colonnes de sql_sizing
34.47. Colonnes de sql_sizing_profiles
34.48. Colonnes de table_constraints
34.49. Colonnes de table_privileges
34.50. Colonnes de tables
34.51. Colonnes de triggered_update_columns
34.52. Colonnes de triggers
34.53. Colonnes de udt_privileges
34.54. Colonnes de usage_privileges
34.55. Colonnes de user_defined_types
34.56. Colonnes de user_mapping_options
34.57. Colonnes de user_mappings
34.58. Colonnes de view_column_usage
34.59. Colonnes de view_routine_usage
34.60. Colonnes de view_table_usage
34.61. Colonnes de views
35.1. Équivalence des types C et des types SQL intégrés
35.2. Stratégies B-tree
35.3. Stratégies de découpage
35.4. Stratégies « R-tree » pour GiST à deux dimensions
35.5. Stratégies point SP-GiST
35.6. Stratégies des tableaux GIN
35.7. Fonctions d'appui de B-tree
35.8. Fonctions d'appui pour découpage
35.9. Fonctions d'appui pour GiST
35.10. Fonctions de support SP-GiST
35.11. Fonctions d'appui GIN
37.1. Support des triggers sur évènement par commande
40.1. Diagnostiques et erreurs
48.1. Catalogues système
48.2. Les colonnes de pg_aggregate
48.3. Colonnes de pg_am
48.4. Colonnes de pg_amop
48.5. Colonnes de pg_amproc
48.6. Colonnes de pg_attrdef
48.7. Colonnes de pg_attribute
48.8. Colonnes de pg_authid
48.9. Colonnes de pg_auth_members
48.10. Colonnes de pg_cast
48.11. Colonnes de pg_class
48.12. Colonnes de pg_event_trigger
48.13. Colonnes de pg_collation
48.14. Colonnes de pg_constraint
48.15. Colonnes de pg_conversion
48.16. Colonnes de pg_database
48.17. Colonnes de pg_db_role_setting
48.18. Colonnes de pg_default_acl
48.19. Colonnes de pg_depend
48.20. Colonnes de pg_description
48.21. Colonnes de pg_enum
48.22. Colonnes de pg_extension
48.23. Colonnes de pg_foreign_data_wrapper
48.24. Colonnes pg_foreign_server
48.25. Colonnes de pg_foreign_table
48.26. Colonnes de pg_index
48.27. Colonnes de pg_inherits
48.28. Colonnes de pg_language
48.29. Colonnes de pg_largeobject
48.30. Colonnes de pg_largeobject_metadata
48.31. Colonnes de pg_namespace
48.32. Colonnes de pg_opclass
48.33. Colonnes de pg_operator
48.34. Colonnes de pg_opfamily
48.35. Colonnes de pg_pltemplate
48.36. Colonnes de pg_proc
48.37. Colonnes de pg_range
48.38. Colonnes de pg_rewrite
48.39. Colonnes de pg_replication_slots
48.40. Colonnes de pg_seclabel
48.41. Colonnes de pg_shdepend
48.42. Colonnes de pg_shdescription
48.43. Colonnes de pg_shseclabel
48.44. Colonnes de pg_statistic
48.45. Colonnes de pg_tablespace
48.46. Colonnes de pg_trigger
48.47. Colonnes de pg_ts_config
48.48. Colonnes de pg_ts_config_map
48.49. Colonnes de pg_ts_dict
48.50. Colonnes de pg_ts_parser
48.51. Colonnes de pg_ts_template
48.52. Colonnes de pg_type
48.53. Codes typcategory
48.54. Colonnes de pg_user_mapping
48.55. Vues système
48.56. Colonnes de pg_available_extensions
48.57. Colonnes de pg_available_extension_versions
48.58. Colonnes de pg_cursors
48.59. Colonnes de pg_group
48.60. Colonnes de pg_indexes
48.61. Colonnes pg_locks
48.62. Colonnes de pg_matviews
48.63. Colonnes de pg_prepared_statements
48.64. Colonnes de pg_prepared_xacts
48.65. Colonnes de pg_roles
48.66. Colonnes de pg_rules
48.67. Colonnes de pg_seclabels
48.68. Colonnes de pg_settings
48.69. Colonnes de pg_shadow
48.70. Colonnes de pg_stats
48.71. Colonnes de pg_tables
48.72. Colonnes de pg_timezone_abbrevs
48.73. Colonnes de pg_timezone_names
48.74. Colonnes de pg_user
48.75. Colonnes de pg_user_mappings
48.76. Colonnes de pg_views
56.1. Classes d'opérateur GiST internes
57.1. Classes d'opérateur SP-GiST internes
58.1. Classes d'opérateur GIN internes
59.1. Contenu de PGDATA
59.2. Disposition d'une page
59.3. Disposition de PageHeaderData
59.4. Disposition de HeapTupleHeaderData
A.1. Codes d'erreur de PostgreSQL
B.1. Noms de mois
B.2. Noms des jours de la semaine
B.3. Modificateurs de Champs Date/Heure
C.1. Mots-clé SQL
F.1. Fonctions adminpack
F.2. Fonctions obsolètes de adminpack
F.3. Représentations externes d'un cube
F.4. Opérateurs GiST du type cube
F.5. Fonctions cube
F.6. Fonctions earthdistance par cubes
F.7. Opérateurs earthdistance par points
F.8. Opérateurshstore
F.9. Fonctions hstore
F.10. Fonctions intarray
F.11. Opérateurs d'intarray
F.12. Types de données isn
F.13. Fonctions de isn
F.14. Opérateurs ltree
F.15. Fonctions ltree
F.16. Colonnes de pg_buffercache
F.17. Algorithmes supportés par crypt()
F.18. Nombre d'itération pour crypt()
F.19. Vitesse de l'algorithm de hachage
F.20. Résumé de fonctionnalités avec et sans OpenSSL
F.21. Colonnes de pgrowlocks
F.22. Colonnes de pg_stat_statements
F.23. Colonnes de pgstattuple
F.24. Fonctions de pg_trgm
F.25. Opérateurs de pg_trgm
F.26. Représentations externes de seg
F.27. Exemples d'entrées valides de type seg
F.28. Opérateurs GiST du type Seg
F.29. Fonctions Sepgsql
F.30. Fonctions tablefunc
F.31. Paramètres connectby
F.32. Fonctions pour la génération d'UUID
F.33. Fonctions renvoyant des constantes UUID
F.34. Fonctions
F.35. Paramètres de xpath_table
G.1. Variables automatiques
H.1. Interfaces clients maintenus en externe
H.2. Langages procéduraux maintenus en externe

Liste des exemples

8.1. Utilisation des types caractère
8.2. Utilisation du type boolean.
8.3. Utiliser les types de chaînes de bits
10.1. Résolution du type d'opérateur factoriel
10.2. Résolution de types pour les opérateurs de concaténation de chaînes
10.3. Résolution de types pour les opérateurs de valeur absolue et de négation
10.4. Résolution du type d'opérateur avec des inclusions de tableaux
10.5. Opérateur personnalisé sur un domaine
10.6. Résolution de types pour les arguments de la fonction arrondie
10.7. Résolution de types pour les fonctions retournant un segment de chaîne
10.8. Conversion de types pour le stockage de character
10.9. Résolution de types avec des types sous-spécifiés dans une union
10.10. Résolution de types dans une union simple
10.11. Résolution de types dans une union transposée
10.12. Résolution de fonctions à nombre d'arguments variant
10.13. Résolution de type dans une union imbriquée
11.1. Mettre en place un index partiel pour exclure des valeurs courantes
11.2. Mettre en place un index partiel pour exclure les valeurs inintéressantes
11.3. Mettre en place un index d'unicité partiel
19.1. Exemple d'entrées de pg_hba.conf
19.2. Un exemple de fichier pg_ident.conf
31.1. Premier exemple de programme pour libpq
31.2. Deuxième exemple de programme pour libpq
31.3. Troisième exemple de programme pour libpq
32.1. Exemple de programme sur les objets larges avec libpq
33.1. Programme de Démonstration SQLDA
33.2. Programme ECPG Accédant à un Large Object
39.1. Installation manuelle de PL/Perl
40.1. Mettre entre guillemets des valeurs dans des requêtes dynamiques
40.2. Exceptions avec UPDATE/INSERT
40.3. Une procédure trigger PL/pgSQL
40.4. Une procédure d'audit par trigger en PL/pgSQL
40.5. Une fonction trigger en PL/pgSQL sur une vue pour un audit
40.6. Une procédure trigger PL/pgSQL pour maintenir une table résumée
40.7. Une procédure PL/pgSQL pour un trigger d'événement
40.8. Portage d'une fonction simple de PL/SQL vers PL/pgSQL
40.9. Portage d'une fonction qui crée une autre fonction de PL/SQL vers PL/pgSQL
40.10. Portage d'une procédure avec manipulation de chaînes et paramètres OUT de PL/SQL vers PL/pgSQL
40.11. Portage d'une procédure de PL/SQL vers PL/pgSQL
F.1. Créer une table distante pour les journaux applicatifs PostgreSQL au format CSV