PostgreSQL La base de donnees la plus sophistiquee au monde.

Différences

Ci-dessous, les différences entre deux révisions de la page.

Lien vers cette vue comparative

Prochaine révision
Révision précédente
support:trucs_et_astuces:trouver_facilement_la_taille_d_une_table_de_ses_index_et_son_nombre_de_tuples [2008/10/15 16:54]
ioguix créée
support:trucs_et_astuces:trouver_facilement_la_taille_d_une_table_de_ses_index_et_son_nombre_de_tuples [2011/03/01 15:50] (Version actuelle)
zehome Ajout de fonctions pour avoir la taille des tables, en tenant compte de la taille des toast.
Ligne 40: Ligne 40:
 Jean-Paul ARGUDO\\ Jean-Paul ARGUDO\\
 http://dalibo.com | http://dalibo.org  http://dalibo.com | http://dalibo.org 
 +
 +Merci pour cette vue.\\
 +Apres migration en postgres 8.4 j'ai du la modifier pour qu'elle fonctionne.\\
 +En esperant que cela soit utile.
 +<code sql>drop view vue_stats;
 +
 +create view vue_stats as
 +SELECT
 +c.relname as nom,
 +c.reltuples::bigint as tuples,
 +pg_total_relation_size(CAST(c.relname AS TEXT)) as volume_total,
 +pg_relation_size(CAST(c.relname AS TEXT)) as volume_donnees,
 +pg_total_relation_size(CAST(c.relname AS TEXT))-pg_relation_size(CAST(c.relname AS TEXT)) as volume_index
 +FROM pg_catalog.pg_class c
 +JOIN pg_catalog.pg_roles r ON r.oid = c.relowner
 +LEFT JOIN pg_catalog.pg_namespace n ON n.oid = c.relnamespace
 +WHERE c.relkind = 'r'
 +AND n.nspname NOT IN ('pg_catalog', 'pg_toast')
 +AND pg_catalog.pg_table_is_visible(c.oid)
 +ORDER BY 1,2;</code>
 +-- \\
 +Jean-Philippe FARCY\\
 +http://www.sigma.fr
 +
 +
 +Les fonctions ci dessus ne tiennent pas compte des tables toast dans leur calculs.
 +Voici des fonctions qui en tiennent compte:
 +<code sql>
 +CREATE OR REPLACE VIEW view_relations_size AS 
 +SELECT
 +    c.relname AS name,
 +    c.reltuples::bigint AS tuples,
 +    pg_relation_size(c.oid) AS table_size,
 +    pg_total_relation_size(c.oid)-pg_relation_size(c.oid) - (CASE WHEN c.reltoastrelid <> 0 THEN pg_relation_size(c.reltoastrelid) ELSE 0 END) AS index_size,
 +    CASE WHEN c.reltoastrelid <> 0 THEN pg_relation_size(c.reltoastrelid) ELSE 0 END AS toast_size,
 +    pg_total_relation_size(c.oid) AS total_size
 +FROM 
 +    pg_catalog.pg_class c
 +JOIN 
 +    pg_catalog.pg_roles r ON r.oid = c.relowner
 +LEFT JOIN 
 +    pg_catalog.pg_namespace n ON n.oid = c.relnamespace
 +WHERE 
 +    c.relkind = 'r'
 +AND n.nspname NOT IN ('pg_catalog', 'pg_toast')
 +AND pg_catalog.pg_table_is_visible(c.oid)
 +ORDER BY total_size DESC;
 +
 +CREATE VIEW view_relations_size_pretty AS
 +SELECT
 +    name,
 +    tuples,
 +    pg_size_pretty(table_size) AS table_size,
 +    pg_size_pretty(index_size) AS index_size,
 +    pg_size_pretty(toast_size) AS toast_size,
 +    pg_size_pretty(total_size) AS total_size
 +FROM view_relations_size;
 +</code>
 +-- \\
 +Laurent Coustet
 +
 
support/trucs_et_astuces/trouver_facilement_la_taille_d_une_table_de_ses_index_et_son_nombre_de_tuples.1224082473.txt.gz · Dernière modification: 2008/10/15 16:54 de ioguix