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

Version anglaise

Documentation PostgreSQL 9.6.24

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
15. Requêtes parallélisées
III. Administration du serveur
16. Procédure d'installation de PostgreSQL du code source
17. Installation à partir du code source sur Windows
18. Configuration du serveur et mise en place
19. Configuration du serveur
20. Authentification du client
21. Rôles de la base de données
22. Administration des bases de données
23. Localisation
24. Planifier les tâches de maintenance
25. Sauvegardes et restaurations
26. Haute disponibilité, répartition de charge et réplication
27. Configuration de la récupération
28. Surveiller l'activité de la base de données
29. Surveiller l'utilisation des disques
30. Fiabilité et journaux de transaction
31. Tests de régression
IV. Interfaces client
32. libpq - Bibliothèque C
33. Objets larges
34. ECPG SQL embarqué en C
35. Schéma d'information
V. Programmation serveur
36. Étendre SQL
37. Déclencheurs (triggers)
38. Déclencheurs (triggers) sur évènement
39. Système de règles
40. Langages de procédures
41. PL/pgSQL - Langage de procédures SQL
42. PL/Tcl - Langage de procédures Tcl
43. PL/Perl - Langage de procédures Perl
44. PL/Python - Langage de procédures Python
45. Interface de programmation serveur
46. Processus en tâche de fond (background worker)
47. Décodage logique (Logical Decoding)
48. Tracer la progression de la réplication
VI. Référence
I. Commandes SQL
II. Applications client de PostgreSQL
III. Applications relatives au serveur PostgreSQL
VII. Internes
49. Présentation des mécanismes internes de PostgreSQL
50. Catalogues système
51. Protocole client/serveur
52. Conventions de codage pour PostgreSQL
53. Support natif des langues
54. Écrire un gestionnaire de langage procédural
55. Écrire un wrapper de données distantes
56. Écrire une méthode d'échantillonnage de table
57. Écrire un module de parcours personnalisé
58. Optimiseur génétique de requêtes (Genetic Query Optimizer)
59. Définition de l'interface des méthodes d'accès aux index
60. Enregistrements génériques des journaux de transactions
61. Index GiST
62. Index SP-GiST
63. Index GIN
64. Index BRIN
65. Stockage physique de la base de données
66. Interface du moteur, BKI
67. 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 illustrations

58.1. Diagramme structuré d'un algorithme génétique

Liste des tableaux

4.1. Séquences d'échappements avec antislash
4.2. Précédence des opérateurs (du plus haut vers le plus bas)
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. Prédicats de comparaison
9.3. Fonctions de comparaison
9.4. Opérateurs mathématiques
9.5. Fonctions mathématiques
9.6. Fonctions de génération de nombres aléatoires
9.7. Fonctions trigonométriques
9.8. Fonctions et opérateurs SQL pour le type chaîne
9.9. Autres fonctions de chaîne
9.10. Conversions intégrées
9.11. Fonctions et opérateurs SQL pour chaînes binaires
9.12. Autres fonctions sur les chaînes binaires
9.13. Opérateurs sur les chaînes de bits
9.14. Opérateurs de correspondance des expressions rationnelles
9.15. Atomes d'expressions rationnelles
9.16. quantificateur d'expressions rationnelles
9.17. Contraintes des expressions rationnelles
9.18. Échappements de caractère dans les expressions rationnelles
9.19. Échappement de raccourcis de classes dans les expressions rationnelles
9.20. Échappements de contrainte dans les expressions rationnelles
9.21. Rétroréférences dans les expressions rationnelles
9.22. Lettres d'option intégrées à une ERA
9.23. Fonctions de formatage
9.24. Modèles pour le formatage de champs de type date/heure
9.25. Modificateurs de motifs pour le formatage des dates/heures
9.26. Motifs de modèle pour le formatage de valeurs numériques
9.27. Modifications de motifs pour le formatage numérique
9.28. Exemples avec to_char
9.29. Opérateurs date/heure
9.30. Fonctions date/heure
9.31. Variantes AT TIME ZONE
9.32. Fonctions de support enum
9.33. Opérateurs géométriques
9.34. Fonctions géométriques
9.35. Fonctions de conversion de types géométriques
9.36. Opérateurs cidr et inet
9.37. Fonctions cidr et inet
9.38. Fonctions macaddr
9.39. Opérateurs de recherche plein texte
9.40. Fonctions de la recherche plein texte
9.41. Fonctions de débogage de la recherche plein texte
9.42. Opérateurs json et jsonb
9.43. Opérateurs jsonb supplémentaires
9.44. Fonctions de création de données JSON
9.45. Fonctions de traitement du JSON
9.46. Fonctions séquence
9.47. Opérateurs pour les tableaux
9.48. Fonctions pour les tableaux
9.49. Opérateurs pour les types range
9.50. Fonctions range
9.51. Fonctions d'agrégat générales
9.52. Fonctions d'agrégats pour les statistiques
9.53. Fonctions d'agrégat par ensemble trié
9.54. Fonctions d'agrégat par ensemble hypothétique
9.55. Opérations de regroupement
9.56. Fonctions Window généralistes
9.57. Fonctions de génération de séries
9.58. Fonctions de génération d'indices
9.59. Fonctions d'information de session
9.60. Fonctions de consultation des privilèges d'accès
9.61. Fonctions d'interrogation de visibilité dans les schémas
9.62. Fonctions d'information du catalogue système
9.63. Propriétés des colonnes d'index
9.64. Propriétés des index
9.65. Propriétés des méthodes d'accès aux index
9.66. Fonctions d'information et d'adressage des objets
9.67. Fonctions d'informations sur les commentaires
9.68. ID de transaction et instantanés
9.69. Composants de l'instantané
9.70. Informations sur les transactions validées
9.71. Fonctions des données de contrôle
9.72. Colonnes de pg_control_checkpoint
9.73. Colonnes de pg_control_system
9.74. Colonnes de pg_control_init
9.75. Colonnes de pg_control_recovery
9.76. Fonctions agissant sur les paramètres de configuration
9.77. Fonctions d'envoi de signal au serveur
9.78. Fonctions de contrôle de la sauvegarde
9.79. Fonctions d'information sur la restauration
9.80. Fonctions de contrôle de la restauration
9.81. Fonction de synchronisation de snapshot
9.82. Fonctions SQL pour la réplication
9.83. Fonctions de calcul de la taille des objets de la base de données
9.84. Fonctions de récupération de l'emplacement des objets de la base de données
9.85. Fonctions de maintenance des index
9.86. Fonctions d'accès générique aux fichiers
9.87. Fonctions de verrous consultatifs
9.88. Table Rewrite information
12.1. Types de jeton de l'analyseur par défaut
13.1. Niveaux d'isolation des transactions
13.2. Modes de verrou conflictuels
13.3. Verrous en conflit au niveau ligne
18.1. Paramètres system v ipc
18.2. Utilisation des fichiers serveur SSL
19.1. Modes pour synchronous_commit
19.2. Niveaux de sévérité des messages
19.3. Clé d'option courte
21.1. Rôles par défaut
23.1. Jeux de caractères de PostgreSQL
23.2. Conversion de jeux de caractères client/serveur
26.1. Matrice de fonctionnalités : haute disponibilité, répartition de charge et réplication
28.1. Vues statistiques dynamiques
28.2. Vues sur les statistiques récupérées
28.3. Vue pg_stat_activity
28.4. Description de wait_event
28.5. Vue pg_stat_replication
28.6. Vue pg_stat_wal_receiver
28.7. Vue pg_stat_ssl
28.8. Vue pg_stat_archiver
28.9. Vue pg_stat_bgwriter
28.10. Vue pg_stat_database
28.11. Vue pg_stat_database_conflicts
28.12. Vue pg_stat_all_tables
28.13. Vue pg_stat_all_indexes
28.14. Vue pg_statio_all_tables
28.15. Vue pg_statio_all_indexes
28.16. Vue pg_statio_all_sequences
28.17. Vue pg_stat_user_functions
28.18. Fonctions supplémentaires de statistiques
28.19. Fonctions statistiques par processus serveur
28.20. Vue pg_stat_progress_vacuum
28.21. Phases du VACUUM
28.22. Sondes disponibles pour DTrace
28.23. Types définis utilisés comme paramètres de sonde
32.1. Description des modes SSL
32.2. Utilisation des fichiers SSL libpq/client
33.1. Fonctions SQL pour les Large Objects
34.1. Correspondance Entre les Types PostgreSQL et les Types de Variables C
34.2. Formats d'Entrée Valides pour PGTYPESdate_from_asc
34.3. Formats d'Entrée Valides pour PGTYPESdate_fmt_asc
34.4. Formats d'Entrée Valides pour rdefmtdate
34.5. Formats d'Entrée Valide pour PGTYPEStimestamp_from_asc
35.1. Colonnes de information_schema_catalog_name
35.2. Colonnes de administrable_role_authorizations
35.3. Colonnes de applicable_roles
35.4. Colonnes de attributes
35.5. Colonnes de character_sets
35.6. Colonnes de check_constraint_routine_usage
35.7. Colonnes de check_constraints
35.8. Colonnes de collations
35.9. Colonnes de collation_character_set_applicability
35.10. Colonnes de column_domain_usage
35.11. Colonnes de column_options
35.12. Colonnes de column_privileges
35.13. Colonnes de column_udt_usage
35.14. Colonnes de columns
35.15. Colonnes de constraint_column_usage
35.16. Colonnes de constraint_table_usage
35.17. Colonnes de data_type_privileges
35.18. Colonnes de domain_constraints
35.19. Colonnes de domain_udt_usage
35.20. Colonnes de domains
35.21. Colonnes de element_types
35.22. Colonnes de enabled_roles
35.23. Colonnes de foreign_data_wrapper_options
35.24. Colonnes de foreign_data_wrappers
35.25. Colonnes de foreign_server_options
35.26. Colonnes de foreign_servers
35.27. Colonnes de foreign_table_options
35.28. Colonnes de foreign_tables
35.29. Colonnes de key_column_usage
35.30. Colonnes de parameters
35.31. Colonnes de referential_constraints
35.32. Colonnes de role_column_grants
35.33. Colonnes de role_routine_grants
35.34. Colonnes de role_table_grants
35.35. Colonnes de role_udt_grants
35.36. Colonnes de role_usage_grants
35.37. Colonnes de routine_privileges
35.38. Colonnes de routines
35.39. Colonnes de schemata
35.40. Colonnes de sequences
35.41. Colonnes de sql_features
35.42. Colonnes de sql_implementation_info
35.43. Colonnes de sql_languages
35.44. Colonnes de sql_packages
35.45. Colonnes de sql_parts
35.46. Colonnes de sql_sizing
35.47. Colonnes de sql_sizing_profiles
35.48. Colonnes de table_constraints
35.49. Colonnes de table_privileges
35.50. Colonnes de tables
35.51. Colonnes de transforms
35.52. Colonnes de triggered_update_columns
35.53. Colonnes de triggers
35.54. Colonnes de udt_privileges
35.55. Colonnes de usage_privileges
35.56. Colonnes de user_defined_types
35.57. Colonnes de user_mapping_options
35.58. Colonnes de user_mappings
35.59. Colonnes de view_column_usage
35.60. Colonnes de view_routine_usage
35.61. Colonnes de view_table_usage
35.62. Colonnes de views
36.1. Équivalence des types C et des types SQL intégrés
36.2. Stratégies B-tree
36.3. Stratégies de découpage
36.4. Stratégies « R-tree » pour GiST à deux dimensions
36.5. Stratégies point SP-GiST
36.6. Stratégies des tableaux GIN
36.7. Stratégies MinMax pour BRIN
36.8. Fonctions d'appui de B-tree
36.9. Fonctions d'appui pour découpage
36.10. Fonctions d'appui pour GiST
36.11. Fonctions de support SP-GiST
36.12. Fonctions d'appui GIN
36.13. Fonctions de support BRIN
38.1. Support des triggers sur évènement par commande
41.1. Éléments de diagnostique disponibles
41.2. Diagnostiques et erreurs
238. Politiques appliquées par type de commande
239. Variables automatiques
240. Fonctions pgbench
50.1. Catalogues système
50.2. Les colonnes de pg_aggregate
50.3. Colonnes de pg_am
50.4. Colonnes de pg_amop
50.5. Colonnes de pg_amproc
50.6. Colonnes de pg_attrdef
50.7. Colonnes de pg_attribute
50.8. Colonnes de pg_authid
50.9. Colonnes de pg_auth_members
50.10. Colonnes de pg_cast
50.11. Colonnes de pg_class
50.12. Colonnes de pg_event_trigger
50.13. Colonnes de pg_collation
50.14. Colonnes de pg_constraint
50.15. Colonnes de pg_conversion
50.16. Colonnes de pg_database
50.17. Colonnes de pg_db_role_setting
50.18. Colonnes de pg_default_acl
50.19. Colonnes de pg_depend
50.20. Colonnes de pg_description
50.21. Colonnes de pg_enum
50.22. Colonnes de pg_extension
50.23. Colonnes de pg_foreign_data_wrapper
50.24. Colonnes de pg_foreign_server
50.25. Colonnes de pg_foreign_table
50.26. Colonnes de pg_index
50.27. Colonnes de pg_inherits
50.28. Colonnes de pg_init_privs
50.29. Colonnes de pg_language
50.30. Colonnes de pg_largeobject
50.31. Colonnes de pg_largeobject_metadata
50.32. Colonnes de pg_namespace
50.33. Colonnes de pg_opclass
50.34. Colonnes de pg_operator
50.35. Colonnes de pg_opfamily
50.36. Colonnes de pg_pltemplate
50.37. Colonnes de pg_policy
50.38. Colonnes de pg_proc
50.39. Colonnes de pg_range
50.40. Colonnes de pg_replication_origin
50.41. Colonnes de pg_rewrite
50.42. Colonnes de pg_seclabel
50.43. Colonnes de pg_shdepend
50.44. Colonnes de pg_shdescription
50.45. Colonnes de pg_shseclabel
50.46. Colonnes de pg_statistic
50.47. Colonnes de pg_tablespace
50.48. Colonnes de pg_transform
50.49. Colonnes de pg_trigger
50.50. Colonnes de pg_ts_config
50.51. Colonnes de pg_ts_config_map
50.52. Colonnes de pg_ts_dict
50.53. Colonnes de pg_ts_parser
50.54. Colonnes de pg_ts_template
50.55. Colonnes de pg_type
50.56. Codes typcategory
50.57. Colonnes de pg_user_mapping
50.58. Vues système
50.59. Colonnes de pg_available_extensions
50.60. Colonnes de pg_available_extension_versions
50.61. Colonnes de pg_config
50.62. Colonnes de pg_cursors
50.63. Colonnes de pg_file_settings
50.64. Colonnes de pg_group
50.65. Colonnes de pg_indexes
50.66. Colonnes de pg_locks
50.67. Colonnes de pg_matviews
50.68. Colonnes de pg_policies
50.69. Colonnes de pg_prepared_statements
50.70. Colonnes de pg_prepared_xacts
50.71. Colonnes de pg_replication_origin_status
50.72. Colonnes de pg_replication_slots
50.73. Colonnes de pg_roles
50.74. Colonnes de pg_rules
50.75. Colonnes de pg_seclabels
50.76. Colonnes de pg_settings
50.77. Colonnes de pg_shadow
50.78. Colonnes de pg_stats
50.79. Colonnes de pg_tables
50.80. Colonnes de pg_timezone_abbrevs
50.81. Colonnes de pg_timezone_names
50.82. Colonnes de pg_user
50.83. Colonnes de pg_user_mappings
50.84. Colonnes de pg_views
61.1. Classes d'opérateur GiST internes
62.1. Classes d'opérateur SP-GiST internes
63.1. Classes d'opérateur GIN internes
64.1. Classe d'opérateur BRIN intégrée
64.2. Procédure et numéros de support pour les classes d'opérateur Minmax
64.3. Procédures et numéros de support pour les classes d'opérateur d'inclusion
65.1. Contenu de PGDATA
65.2. Disposition d'une page
65.3. Disposition de PageHeaderData
65.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 de adminpack
F.2. Fonctions obsolètes de adminpack
F.3. Représentations externes d'un cube
F.4. Opérateurs pour 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. Colonnes de pgstattuple_approx
F.25. Fonctions de pg_trgm
F.26. Opérateurs de pg_trgm
F.27. Représentations externes de seg
F.28. Exemples d'entrées valides de type seg
F.29. Opérateurs GiST du type Seg
F.30. Fonctions Sepgsql
F.31. Fonctions tablefunc
F.32. Paramètres connectby
F.33. Fonctions pour la génération d'UUID
F.34. Fonctions renvoyant des constantes UUID
F.35. Fonctions
F.36. Paramètres de xpath_table
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
9.1. Feuille de style XSLT pour convertir du SQL/XML en HTML
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
20.1. Exemple d'entrées de pg_hba.conf
20.2. Un exemple de fichier pg_ident.conf
32.1. Premier exemple de programme pour libpq
32.2. Deuxième exemple de programme pour libpq
32.3. Troisième exemple de programme pour libpq
33.1. Exemple de programme sur les objets larges avec libpq
34.1. Programme de Démonstration SQLDA
34.2. Programme ECPG Accédant à un Large Object
40.1. Installation manuelle de PL/Perl
41.1. Mettre entre guillemets des valeurs dans des requêtes dynamiques
41.2. Exceptions avec UPDATE/INSERT
41.3. Une procédure trigger PL/pgSQL
41.4. Une procédure d'audit par trigger en PL/pgSQL
41.5. Une fonction trigger en PL/pgSQL sur une vue pour un audit
41.6. Une procédure trigger PL/pgSQL pour maintenir une table résumée
41.7. Une procédure PL/pgSQL pour un trigger d'événement
41.8. Portage d'une fonction simple de PL/SQL vers PL/pgSQL
41.9. Portage d'une fonction qui crée une autre fonction de PL/SQL vers PL/pgSQL
41.10. Portage d'une procédure avec manipulation de chaînes et paramètres OUT de PL/SQL vers PL/pgSQL
41.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