Commit c9a64909 authored by Tom Lane's avatar Tom Lane

Clean up some leftover problems in pgstattuple: remove unwanted and

unportable elog(NOTICE) report, fix install/uninstall sequence.
Itagaki Takahiro
parent 57bfb27e
...@@ -561,7 +561,7 @@ bt_page_items(PG_FUNCTION_ARGS) ...@@ -561,7 +561,7 @@ bt_page_items(PG_FUNCTION_ARGS)
values[j] = palloc(32); values[j] = palloc(32);
snprintf(values[j++], 32, "(%u,%u)", blkno, itup->t_tid.ip_posid); snprintf(values[j++], 32, "(%u,%u)", blkno, itup->t_tid.ip_posid);
values[j] = palloc(32); values[j] = palloc(32);
snprintf(values[j++], 32, "%d", IndexTupleSize(itup)); snprintf(values[j++], 32, "%d", (int) IndexTupleSize(itup));
values[j] = palloc(32); values[j] = palloc(32);
snprintf(values[j++], 32, "%c", IndexTupleHasNulls(itup) ? 't' : 'f'); snprintf(values[j++], 32, "%c", IndexTupleHasNulls(itup) ? 't' : 'f');
values[j] = palloc(32); values[j] = palloc(32);
......
/* /*
* $PostgreSQL: pgsql/contrib/pgstattuple/pgstattuple.c,v 1.23 2006/07/11 17:26:58 momjian Exp $ * $PostgreSQL: pgsql/contrib/pgstattuple/pgstattuple.c,v 1.24 2006/09/04 02:03:04 tgl Exp $
* *
* Copyright (c) 2001,2002 Tatsuo Ishii * Copyright (c) 2001,2002 Tatsuo Ishii
* *
...@@ -59,35 +59,19 @@ typedef struct pgstattuple_type ...@@ -59,35 +59,19 @@ typedef struct pgstattuple_type
uint64 free_space; /* free/reusable space in bytes */ uint64 free_space; /* free/reusable space in bytes */
} pgstattuple_type; } pgstattuple_type;
/*
* struct pgstat_btree_type
*/
typedef struct pgstat_btree_type
{
pgstattuple_type base; /* inherits pgstattuple_type */
uint64 continuous;
uint64 forward;
uint64 backward;
} pgstat_btree_type;
typedef void (*pgstat_page)(pgstattuple_type *, Relation, BlockNumber); typedef void (*pgstat_page)(pgstattuple_type *, Relation, BlockNumber);
static Datum build_pgstattuple_type(pgstattuple_type *stat, static Datum build_pgstattuple_type(pgstattuple_type *stat,
FunctionCallInfo fcinfo); FunctionCallInfo fcinfo);
static Datum pgstat_relation(Relation rel, FunctionCallInfo fcinfo); static Datum pgstat_relation(Relation rel, FunctionCallInfo fcinfo);
static Datum pgstat_heap(Relation rel, FunctionCallInfo fcinfo); static Datum pgstat_heap(Relation rel, FunctionCallInfo fcinfo);
static Datum pgstat_btree(Relation rel, FunctionCallInfo fcinfo);
static void pgstat_btree_page(pgstattuple_type *stat, static void pgstat_btree_page(pgstattuple_type *stat,
Relation rel, BlockNumber blkno); Relation rel, BlockNumber blkno);
static Datum pgstat_hash(Relation rel, FunctionCallInfo fcinfo);
static void pgstat_hash_page(pgstattuple_type *stat, static void pgstat_hash_page(pgstattuple_type *stat,
Relation rel, BlockNumber blkno); Relation rel, BlockNumber blkno);
static Datum pgstat_gist(Relation rel, FunctionCallInfo fcinfo);
static void pgstat_gist_page(pgstattuple_type *stat, static void pgstat_gist_page(pgstattuple_type *stat,
Relation rel, BlockNumber blkno); Relation rel, BlockNumber blkno);
static Datum pgstat_index(pgstattuple_type *stat, static Datum pgstat_index(Relation rel, BlockNumber start,
Relation rel, BlockNumber start,
pgstat_page pagefn, FunctionCallInfo fcinfo); pgstat_page pagefn, FunctionCallInfo fcinfo);
static void pgstat_index_page(pgstattuple_type *stat, Page page, static void pgstat_index_page(pgstattuple_type *stat, Page page,
OffsetNumber minoff, OffsetNumber maxoff); OffsetNumber minoff, OffsetNumber maxoff);
...@@ -217,11 +201,14 @@ pgstat_relation(Relation rel, FunctionCallInfo fcinfo) ...@@ -217,11 +201,14 @@ pgstat_relation(Relation rel, FunctionCallInfo fcinfo)
switch(rel->rd_rel->relam) switch(rel->rd_rel->relam)
{ {
case BTREE_AM_OID: case BTREE_AM_OID:
return pgstat_btree(rel, fcinfo); return pgstat_index(rel, BTREE_METAPAGE + 1,
pgstat_btree_page, fcinfo);
case HASH_AM_OID: case HASH_AM_OID:
return pgstat_hash(rel, fcinfo); return pgstat_index(rel, HASH_METAPAGE + 1,
pgstat_hash_page, fcinfo);
case GIST_AM_OID: case GIST_AM_OID:
return pgstat_gist(rel, fcinfo); return pgstat_index(rel, GIST_ROOT_BLKNO + 1,
pgstat_gist_page, fcinfo);
case GIN_AM_OID: case GIN_AM_OID:
err = "gin index"; err = "gin index";
break; break;
...@@ -321,36 +308,13 @@ pgstat_heap(Relation rel, FunctionCallInfo fcinfo) ...@@ -321,36 +308,13 @@ pgstat_heap(Relation rel, FunctionCallInfo fcinfo)
} }
/* /*
* pgstat_btree -- returns live/dead tuples info in a btree index * pgstat_btree_page -- check tuples in a btree page
*/
static Datum
pgstat_btree(Relation rel, FunctionCallInfo fcinfo)
{
pgstat_btree_type stat = { { 0 } };
Datum datum;
datum = pgstat_index((pgstattuple_type *) &stat, rel,
BTREE_METAPAGE + 1, pgstat_btree_page, fcinfo);
ereport(NOTICE,
(errmsg("%.2f%% fragmented",
100.0 * (stat.forward + stat.backward) /
(stat.continuous + stat.forward + stat.backward)),
errhint("continuous=%llu, forward=%llu, backward=%llu",
stat.continuous, stat.forward, stat.backward)));
return datum;
}
/*
* pgstat_btree_page
*/ */
static void static void
pgstat_btree_page(pgstattuple_type *stat, Relation rel, BlockNumber blkno) pgstat_btree_page(pgstattuple_type *stat, Relation rel, BlockNumber blkno)
{ {
Buffer buf; Buffer buf;
Page page; Page page;
pgstat_btree_type *btstat = (pgstat_btree_type *)stat;
buf = ReadBuffer(rel, blkno); buf = ReadBuffer(rel, blkno);
LockBuffer(buf, BT_READ); LockBuffer(buf, BT_READ);
...@@ -373,16 +337,6 @@ pgstat_btree_page(pgstattuple_type *stat, Relation rel, BlockNumber blkno) ...@@ -373,16 +337,6 @@ pgstat_btree_page(pgstattuple_type *stat, Relation rel, BlockNumber blkno)
} }
else if (P_ISLEAF(opaque)) else if (P_ISLEAF(opaque))
{ {
/* check fragmentation */
if (P_RIGHTMOST(opaque))
btstat->continuous++;
else if (opaque->btpo_next < blkno)
btstat->backward++;
else if (opaque->btpo_next > blkno + 1)
btstat->forward++;
else
btstat->continuous++;
pgstat_index_page(stat, page, P_FIRSTDATAKEY(opaque), pgstat_index_page(stat, page, P_FIRSTDATAKEY(opaque),
PageGetMaxOffsetNumber(page)); PageGetMaxOffsetNumber(page));
} }
...@@ -396,17 +350,7 @@ pgstat_btree_page(pgstattuple_type *stat, Relation rel, BlockNumber blkno) ...@@ -396,17 +350,7 @@ pgstat_btree_page(pgstattuple_type *stat, Relation rel, BlockNumber blkno)
} }
/* /*
* pgstat_hash -- returns live/dead tuples info in a hash index * pgstat_hash_page -- check tuples in a hash page
*/
static Datum
pgstat_hash(Relation rel, FunctionCallInfo fcinfo)
{
pgstattuple_type stat = { 0 };
return pgstat_index(&stat, rel, HASH_METAPAGE + 1, pgstat_hash_page, fcinfo);
}
/*
* pgstat_hash_page
*/ */
static void static void
pgstat_hash_page(pgstattuple_type *stat, Relation rel, BlockNumber blkno) pgstat_hash_page(pgstattuple_type *stat, Relation rel, BlockNumber blkno)
...@@ -448,17 +392,7 @@ pgstat_hash_page(pgstattuple_type *stat, Relation rel, BlockNumber blkno) ...@@ -448,17 +392,7 @@ pgstat_hash_page(pgstattuple_type *stat, Relation rel, BlockNumber blkno)
} }
/* /*
* pgstat_gist -- returns live/dead tuples info in a gist index * pgstat_gist_page -- check tuples in a gist page
*/
static Datum
pgstat_gist(Relation rel, FunctionCallInfo fcinfo)
{
pgstattuple_type stat = { 0 };
return pgstat_index(&stat, rel, GIST_ROOT_BLKNO + 1, pgstat_gist_page, fcinfo);
}
/*
* pgstat_gist_page
*/ */
static void static void
pgstat_gist_page(pgstattuple_type *stat, Relation rel, BlockNumber blkno) pgstat_gist_page(pgstattuple_type *stat, Relation rel, BlockNumber blkno)
...@@ -488,11 +422,12 @@ pgstat_gist_page(pgstattuple_type *stat, Relation rel, BlockNumber blkno) ...@@ -488,11 +422,12 @@ pgstat_gist_page(pgstattuple_type *stat, Relation rel, BlockNumber blkno)
* pgstat_index -- returns live/dead tuples info in a generic index * pgstat_index -- returns live/dead tuples info in a generic index
*/ */
static Datum static Datum
pgstat_index(pgstattuple_type *stat, Relation rel, BlockNumber start, pgstat_index(Relation rel, BlockNumber start, pgstat_page pagefn,
pgstat_page pagefn, FunctionCallInfo fcinfo) FunctionCallInfo fcinfo)
{ {
BlockNumber nblocks; BlockNumber nblocks;
BlockNumber blkno; BlockNumber blkno;
pgstattuple_type stat = { 0 };
blkno = start; blkno = start;
for (;;) for (;;)
...@@ -505,17 +440,17 @@ pgstat_index(pgstattuple_type *stat, Relation rel, BlockNumber start, ...@@ -505,17 +440,17 @@ pgstat_index(pgstattuple_type *stat, Relation rel, BlockNumber start,
/* Quit if we've scanned the whole relation */ /* Quit if we've scanned the whole relation */
if (blkno >= nblocks) if (blkno >= nblocks)
{ {
stat->table_len = (uint64) nblocks * BLCKSZ; stat.table_len = (uint64) nblocks * BLCKSZ;
break; break;
} }
for (; blkno < nblocks; blkno++) for (; blkno < nblocks; blkno++)
pagefn(stat, rel, blkno); pagefn(&stat, rel, blkno);
} }
relation_close(rel, AccessShareLock); relation_close(rel, AccessShareLock);
return build_pgstattuple_type(stat, fcinfo); return build_pgstattuple_type(&stat, fcinfo);
} }
/* /*
......
...@@ -26,7 +26,6 @@ LANGUAGE C STRICT; ...@@ -26,7 +26,6 @@ LANGUAGE C STRICT;
-- --
-- pgstatindex -- pgstatindex
-- --
DROP TYPE pgstatindex_type CASCADE;
CREATE TYPE pgstatindex_type AS ( CREATE TYPE pgstatindex_type AS (
version int4, version int4,
tree_level int4, tree_level int4,
...@@ -48,7 +47,6 @@ LANGUAGE 'C' STRICT; ...@@ -48,7 +47,6 @@ LANGUAGE 'C' STRICT;
-- --
-- bt_metap() -- bt_metap()
-- --
DROP TYPE bt_metap_type CASCADE;
CREATE TYPE bt_metap_type AS ( CREATE TYPE bt_metap_type AS (
magic int4, magic int4,
version int4, version int4,
...@@ -66,7 +64,6 @@ LANGUAGE 'C' STRICT; ...@@ -66,7 +64,6 @@ LANGUAGE 'C' STRICT;
-- --
-- bt_page_stats() -- bt_page_stats()
-- --
DROP TYPE bt_page_stats_type CASCADE;
CREATE TYPE bt_page_stats_type AS ( CREATE TYPE bt_page_stats_type AS (
blkno int4, blkno int4,
type char, type char,
...@@ -81,8 +78,6 @@ CREATE TYPE bt_page_stats_type AS ( ...@@ -81,8 +78,6 @@ CREATE TYPE bt_page_stats_type AS (
btpo_flags int4 btpo_flags int4
); );
DROP FUNCTION bt_page_stats(text, int4);
CREATE OR REPLACE FUNCTION bt_page_stats(text, int4) CREATE OR REPLACE FUNCTION bt_page_stats(text, int4)
RETURNS bt_page_stats_type RETURNS bt_page_stats_type
AS 'MODULE_PATHNAME', 'bt_page_stats' AS 'MODULE_PATHNAME', 'bt_page_stats'
...@@ -91,7 +86,6 @@ LANGUAGE 'C' STRICT; ...@@ -91,7 +86,6 @@ LANGUAGE 'C' STRICT;
-- --
-- bt_page_items() -- bt_page_items()
-- --
DROP TYPE bt_page_items_type CASCADE;
CREATE TYPE bt_page_items_type AS ( CREATE TYPE bt_page_items_type AS (
itemoffset int4, itemoffset int4,
ctid tid, ctid tid,
...@@ -101,8 +95,6 @@ CREATE TYPE bt_page_items_type AS ( ...@@ -101,8 +95,6 @@ CREATE TYPE bt_page_items_type AS (
data text data text
); );
DROP FUNCTION bt_page_items(text, int4);
CREATE OR REPLACE FUNCTION bt_page_items(text, int4) CREATE OR REPLACE FUNCTION bt_page_items(text, int4)
RETURNS SETOF bt_page_items_type RETURNS SETOF bt_page_items_type
AS 'MODULE_PATHNAME', 'bt_page_items' AS 'MODULE_PATHNAME', 'bt_page_items'
......
...@@ -2,7 +2,19 @@ ...@@ -2,7 +2,19 @@
SET search_path = public; SET search_path = public;
DROP FUNCTION pgstattuple(oid); DROP FUNCTION pgstattuple(oid);
DROP FUNCTION pgstattuple(text); DROP FUNCTION pgstattuple(text);
DROP TYPE pgstattuple_type; DROP TYPE pgstattuple_type;
DROP FUNCTION pgstatindex(text);
DROP TYPE pgstatindex_type;
DROP FUNCTION bt_metap(text);
DROP TYPE bt_metap_type;
DROP FUNCTION bt_page_stats(text, int4);
DROP TYPE bt_page_stats_type;
DROP FUNCTION bt_page_items(text, int4);
DROP TYPE bt_page_items_type;
DROP FUNCTION pg_relpages(text);
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment