Documentation PostgreSQL 9.5.4

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)
47. 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
48. Présentation des mécanismes internes de PostgreSQL
49. Catalogues système
50. Protocole client/serveur
51. Conventions de codage pour PostgreSQL
52. Support natif des langues
53. Écrire un gestionnaire de langage procédural
54. Écrire un wrapper de données distantes
55. Écrire une méthode d'échantillonnage de table
56. Écrire un module de parcours personnalisé
57. Optimiseur génétique de requêtes (Genetic Query Optimizer)
58. Définition de l'interface des méthodes d'accès aux index
59. Index GiST
60. Index SP-GiST
61. Index GIN
62. Index BRIN
63. Stockage physique de la base de données
64. Interface du moteur, BKI
65. 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

9.1. Feuille de style XSLT pour convertir du SQL/XML en HTML
57.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™ correspondant
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étro-ré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. Opérations de regroupement
9.54. Fonctions Window généralistes
9.55. Fonctions de génération de séries
9.56. Fonctions de génération d'indices
9.57. Fonctions d'information de session
9.58. Fonctions de consultation des privilèges d'accès
9.59. Fonctions d'interrogation de visibilité dans les schémas
9.60. Fonctions d'information du catalogue système
9.61. Fonctions d'information et d'adressage des objets
9.62. Fonctions d'informations sur les commentaires
9.63. ID de transaction et instantanés
9.64. Composants de l'instantané
9.65. Informations sur les transactions validées
9.66. Fonctions agissant sur les paramètres de configuration
9.67. Fonctions d'envoi de signal au serveur
9.68. Fonctions de contrôle de la sauvegarde
9.69. Fonctions d'information sur la restauration
9.70. Fonctions de contrôle de la restauration
9.71. Fonction de synchronisation de snapshot
9.72. Fonctions SQL pour la réplication
9.73. Fonctions de calcul de la taille des objets de la base de données
9.74. Fonctions de récupération de l'emplacement des objets de la base de données
9.75. Fonctions de maintenance des index
9.76. Fonctions d'accès générique aux fichiers
9.77. Fonctions de verrous consultatifs
9.78. 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
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 dynamiques
27.2. Vues sur les statistiques récupérées
27.3. Vue pg_stat_activity
27.4. Vue pg_stat_replication
27.5. Vue pg_stat_ssl
27.6. Vue pg_stat_archiver
27.7. Vue pg_stat_bgwriter
27.8. Vue pg_stat_database
27.9. Vue pg_stat_database_conflicts
27.10. Vue pg_stat_all_tables
27.11. Vue pg_stat_all_indexes
27.12. Vue pg_statio_all_tables
27.13. Vue pg_statio_all_indexes
27.14. Vue pg_statio_all_sequences
27.15. Vue pg_stat_user_functions
27.16. Fonctions supplémentaires de statistiques
27.17. Fonctions statistiques par processus serveur
27.18. Sondes disponibles pour DTrace
27.19. 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 transforms
34.52. Colonnes de triggered_update_columns
34.53. Colonnes de triggers
34.54. Colonnes de udt_privileges
34.55. Colonnes de usage_privileges
34.56. Colonnes de user_defined_types
34.57. Colonnes de user_mapping_options
34.58. Colonnes de user_mappings
34.59. Colonnes de view_column_usage
34.60. Colonnes de view_routine_usage
34.61. Colonnes de view_table_usage
34.62. 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. Stratégies MinMax pour BRIN
35.8. Fonctions d'appui de B-tree
35.9. Fonctions d'appui pour découpage
35.10. Fonctions d'appui pour GiST
35.11. Fonctions de support SP-GiST
35.12. Fonctions d'appui GIN
35.13. Fonctions de support BRIN
37.1. Support des triggers sur évènement par commande
40.1. Éléments de diagnostique disponibles
40.2. Éléments de diagnostiques d'erreurs
222. Variables automatiques
49.1. Catalogues système
49.2. Les colonnes de pg_aggregate
49.3. Colonnes de pg_am
49.4. Colonnes de pg_amop
49.5. Colonnes de pg_amproc
49.6. Colonnes de pg_attrdef
49.7. Colonnes de pg_attribute
49.8. Colonnes de pg_authid
49.9. Colonnes de pg_auth_members
49.10. Colonnes de pg_cast
49.11. Colonnes de pg_class
49.12. Colonnes de pg_event_trigger
49.13. Colonnes de pg_collation
49.14. Colonnes de pg_constraint
49.15. Colonnes de pg_conversion
49.16. Colonnes de pg_database
49.17. Colonnes de pg_db_role_setting
49.18. Colonnes de pg_default_acl
49.19. Colonnes de pg_depend
49.20. Colonnes de pg_description
49.21. Colonnes de pg_enum
49.22. Colonnes de pg_extension
49.23. Colonnes de pg_foreign_data_wrapper
49.24. Colonnes de pg_foreign_server
49.25. Colonnes de pg_foreign_table
49.26. Colonnes de pg_index
49.27. Colonnes de pg_inherits
49.28. Colonnes de pg_language
49.29. Colonnes de pg_largeobject
49.30. Colonnes de pg_largeobject_metadata
49.31. Colonnes de pg_namespace
49.32. Colonnes de pg_opclass
49.33. Colonnes de pg_operator
49.34. Colonnes de pg_opfamily
49.35. Colonnes de pg_pltemplate
49.36. Colonnes de pg_policy
49.37. Colonnes de pg_proc
49.38. Colonnes de pg_range
49.39. Colonnes de pg_replication_origin
49.40. Colonnes de pg_rewrite
49.41. Colonnes de pg_seclabel
49.42. Colonnes de pg_shdepend
49.43. Colonnes de pg_shdescription
49.44. Colonnes de pg_shseclabel
49.45. Colonnes de pg_statistic
49.46. Colonnes de pg_tablespace
49.47. Colonnes de pg_transform
49.48. Colonnes de pg_trigger
49.49. Colonnes de pg_ts_config
49.50. Colonnes de pg_ts_config_map
49.51. Colonnes de pg_ts_dict
49.52. Colonnes de pg_ts_parser
49.53. Colonnes de pg_ts_template
49.54. Colonnes de pg_type
49.55. Codes typcategory
49.56. Colonnes de pg_user_mapping
49.57. Vues système
49.58. Colonnes de pg_available_extensions
49.59. Colonnes de pg_available_extension_versions
49.60. Colonnes de pg_cursors
49.61. Colonnes de pg_file_settings
49.62. Colonnes de pg_group
49.63. Colonnes de pg_indexes
49.64. Colonnes de pg_locks
49.65. Colonnes de pg_matviews
49.66. Colonnes de pg_policies
49.67. Colonnes de pg_prepared_statements
49.68. Colonnes de pg_prepared_xacts
49.69. Colonnes de pg_replication_origin_status
49.70. Colonnes de pg_replication_slots
49.71. Colonnes de pg_roles
49.72. Colonnes de pg_rules
49.73. Colonnes de pg_seclabels
49.74. Colonnes de pg_settings
49.75. Colonnes de pg_shadow
49.76. Colonnes de pg_stats
49.77. Colonnes de pg_tables
49.78. Colonnes de pg_timezone_abbrevs
49.79. Colonnes de pg_timezone_names
49.80. Colonnes de pg_user
49.81. Colonnes de pg_user_mappings
49.82. Colonnes de pg_views
59.1. Classes d'opérateur GiST internes
60.1. Classes d'opérateur SP-GiST internes
61.1. Classes d'opérateur GIN internes
62.1. Classe d'opérateur BRIN intégrée
62.2. Procédure et numéros de support pour les classes d'opérateur Minmax
62.3. Procédures et numéros de support pour les classes d'opérateur d'inclusion
63.1. Contenu de PGDATA
63.2. Disposition d'une page
63.3. Disposition de PageHeaderData
63.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. Représentations externes d'un cube
F.2. Opérateurs GiST du type cube
F.3. Fonctions cube
F.4. Fonctions earthdistance par cubes
F.5. Opérateurs earthdistance par points
F.6. Opérateurshstore
F.7. Fonctions hstore
F.8. Fonctions intarray
F.9. Opérateurs d'intarray
F.10. Types de données isn
F.11. Fonctions de isn
F.12. Opérateurs ltree
F.13. Fonctions ltree
F.14. Colonnes de pg_buffercache
F.15. Algorithmes supportés par crypt()
F.16. Nombre d'itération pour crypt()
F.17. Vitesse de l'algorithm de hachage
F.18. Résumé de fonctionnalités avec et sans OpenSSL
F.19. Colonnes de pgrowlocks
F.20. Colonnes de pg_stat_statements
F.21. Colonnes de pgstattuple
F.22. Colonnes de pgstattuple_approx
F.23. Fonctions de pg_trgm
F.24. Opérateurs de pg_trgm
F.25. Représentations externes de seg
F.26. Exemples d'entrées valides de type seg
F.27. Opérateurs GiST du type Seg
F.28. Fonctions Sepgsql
F.29. Fonctions tablefunc
F.30. Paramètres connectby
F.31. Fonctions pour la génération d'UUID
F.32. Fonctions renvoyant des constantes UUID
F.33. Fonctions
F.34. 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
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
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 surune 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