| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
 100
 101
 102
 103
 104
 105
 106
 107
 108
 109
 110
 111
 112
 113
 114
 115
 116
 117
 118
 119
 120
 121
 122
 123
 124
 125
 126
 127
 128
 129
 130
 131
 132
 133
 134
 135
 136
 137
 138
 139
 140
 141
 142
 143
 144
 145
 146
 147
 148
 149
 150
 151
 152
 153
 154
 155
 156
 157
 158
 159
 160
 161
 162
 163
 164
 165
 166
 167
 168
 169
 170
 171
 172
 173
 174
 175
 176
 177
 178
 179
 180
 181
 182
 183
 184
 185
 186
 187
 188
 189
 190
 191
 192
 193
 194
 195
 196
 197
 198
 199
 200
 201
 202
 203
 204
 205
 206
 207
 208
 209
 210
 211
 212
 213
 214
 215
 216
 217
 218
 219
 220
 221
 222
 223
 224
 225
 226
 227
 228
 229
 230
 231
 232
 233
 234
 235
 236
 237
 238
 239
 240
 241
 
 | <!--$Id: db_stat.so,v 10.88 2004/10/29 18:42:52 bostic Exp $-->
<!--Copyright 1997-2004 by Sleepycat Software, Inc.-->
<!--All rights reserved.-->
<!--See the file LICENSE for redistribution information.-->
<html>
<head>
<title>Berkeley DB: Db::stat</title>
<meta name="description" content="Berkeley DB: An embedded database programmatic toolkit.">
<meta name="keywords" content="embedded,database,programmatic,toolkit,btree,hash,hashing,transaction,transactions,locking,logging,access method,access methods,Java,C,C++">
</head>
<body bgcolor=white>
<table width="100%"><tr valign=top>
<td>
<h3>Db::stat</h3>
</td>
<td align=right>
<a href="../api_cxx/api_core.html"><img src="../images/api.gif" alt="API"></a>
<a href="../ref/toc.html"><img src="../images/ref.gif" alt="Ref"></a></td>
</tr></table>
<hr size=1 noshade>
<tt>
<h3><pre>
#include <db_cxx.h>
<p>
int
Db::stat(DbTxn *txnid, void *sp, u_int32_t flags);
<p>
int
Db::stat_print(u_int32_t flags);
</pre></h3>
<hr size=1 noshade>
<h3>Description: Db::stat</h3>
<p>The Db::stat method creates a statistical structure and copies a
pointer to it into user-specified memory locations.  Specifically, if
<b>sp</b> is non-NULL, a pointer to the statistics for the database are
copied into the memory location to which it refers.</p>
<h3>Parameters</h3>
<dl compact>
<dt><b>flags</b><dd>The <b>flags</b> parameter must be set to 0 or
one of the following values:
<dl compact>
<dt><a name="DB_DEGREE_2">DB_DEGREE_2</a><dd>Database items read during this operation will have degree 2 isolation.
This ensures the stability of the data items read during the stat
operation but permits that data to be modified or deleted by other
transactions prior to the commit of the specified transaction.
<dt><a name="DB_DIRTY_READ">DB_DIRTY_READ</a><dd>Database items read during this operation may include modified but not
yet committed data.  Silently ignored if the <a href="../api_cxx/db_open.html#DB_DIRTY_READ">DB_DIRTY_READ</a> flag
was not specified when the underlying database was opened.
<dt><a name="DB_FAST_STAT">DB_FAST_STAT</a><dd>Return only the values which do not require traversal of the database.
Among other things, this flag makes it possible for applications to
request key and record counts without incurring the performance penalty
of traversing the entire database.
</dl>
<dt><b>txnid</b><dd>If the operation is to be transaction-protected,
the <b>txnid</b> parameter is a transaction handle returned from
<a href="../api_cxx/txn_begin.html">DbEnv::txn_begin</a>; otherwise, NULL.  
</dl>
<p>Statistical structures are stored in allocated memory.  If application-specific allocation
routines have been declared (see <a href="../api_cxx/env_set_alloc.html">DbEnv::set_alloc</a> for more
information), they are used to allocate the memory; otherwise, the
standard C library <b>malloc</b>(3) is used.  The caller is
responsible for deallocating the memory.  To deallocate the memory, free
the memory reference; references inside the returned memory need not be
individually freed.</p>
<p>If the DB_FAST_STAT flag has not been specified, the
Db::stat method will access some of or all the pages in the database,
incurring a severe performance penalty as well as possibly flushing the
underlying buffer pool.</p>
<p>In the presence of multiple threads or processes accessing an active
database, the information returned by Db::stat may be out-of-date.</p>
<p>If the database was not opened read-only and the DB_FAST_STAT
flag was not specified, the cached key and record numbers will be
updated after the statistical information has been gathered.</p>
<p>The Db::stat method
either returns a non-zero error value
or throws an exception that encapsulates a non-zero error value on
failure, and returns 0 on success.
</p>
<h3>Hash Statistics</h3>
<p>In the case of a Hash database, the statistics are stored in a structure
of type DB_HASH_STAT.  The following fields will be filled in:</p>
<dl compact>
<dt>u_int32_t hash_magic;<dd>Magic number that identifies the file as a Hash file.  Returned if
DB_FAST_STAT is set.
<dt>u_int32_t hash_version;<dd>The version of the Hash database.  Returned if DB_FAST_STAT is
set.
<dt>u_int32_t hash_nkeys;<dd>The number of unique keys in the database.  If DB_FAST_STAT was
specified the count will be the last saved value unless it has never
been calculated, in which case it will be 0. Returned if
DB_FAST_STAT is set.
<dt>u_int32_t hash_ndata;<dd>The number of key/data pairs in the database.  If DB_FAST_STAT
was specified the count will be the last saved value unless it has never
been calculated, in which case it will be 0. Returned if
DB_FAST_STAT is set.
<dt>u_int32_t hash_pagesize;<dd>The underlying Hash database page (and bucket) size, in bytes.
Returned if DB_FAST_STAT is set.
<dt>u_int32_t hash_ffactor;<dd>The desired fill factor (number of items per bucket) specified at
database-creation time.  Returned if DB_FAST_STAT is set.
<dt>u_int32_t hash_buckets;<dd>The number of hash buckets.  Returned if DB_FAST_STAT is set.
<dt>u_int32_t hash_free;<dd>The number of pages on the free list.
<dt>u_int32_t hash_bfree;<dd>The number of bytes free on bucket pages.
<dt>u_int32_t hash_bigpages;<dd>The number of big key/data pages.
<dt>u_int32_t hash_big_bfree;<dd>The number of bytes free on big item pages.
<dt>u_int32_t hash_overflows;<dd>The number of overflow pages (overflow pages are pages that contain items
that did not fit in the main bucket page).
<dt>u_int32_t hash_ovfl_free;<dd>The number of bytes free on overflow pages.
<dt>u_int32_t hash_dup;<dd>The number of duplicate pages.
<dt>u_int32_t hash_dup_free;<dd>The number of bytes free on duplicate pages.
</dl>
<h3>Btree and Recno Statistics</h3>
<p>In the case of a Btree or Recno database, the statistics are stored in
a structure of type DB_BTREE_STAT.  The following fields will be filled
in:</p>
<dl compact>
<dt>u_int32_t bt_magic;<dd>Magic number that identifies the file as a Btree database.  Returned
if DB_FAST_STAT is set.
<dt>u_int32_t bt_version;<dd>The version of the Btree database.  Returned if DB_FAST_STAT
is set.
<dt>u_int32_t bt_nkeys;<dd>For the Btree Access Method, the number of keys in the database.  If
the DB_FAST_STAT flag is not specified or the database was
configured to support record numbers (see <a href="../api_cxx/db_set_flags.html#DB_RECNUM">DB_RECNUM</a>), the count
will be exact.  Otherwise, the count will be the last saved value unless
it has never been calculated, in which case it will be 0.
<p>For the Recno Access Method, the number of records in the database.  If
the database was configured with mutable record numbers (see
<a href="../api_cxx/db_set_flags.html#DB_RENUMBER">DB_RENUMBER</a>), the count will be exact.  Otherwise, if the
DB_FAST_STAT flag is specified the count will be exact but will
include deleted and implicitly created records; if the
DB_FAST_STAT flag is not specified, the count will be exact and
will not include deleted or implicitly created records.</p>
<p>Returned if DB_FAST_STAT is set.</p>
<dt>u_int32_t bt_ndata;<dd>For the Btree Access Method, the number of key/data pairs in the
database.  If the DB_FAST_STAT flag is not specified, the count
will be exact.  Otherwise, the count will be the last saved value unless
it has never been calculated, in which case it will be 0.
<p>For the Recno Access Method, the number of records in the database.  If
the database was configured with mutable record numbers (see
<a href="../api_cxx/db_set_flags.html#DB_RENUMBER">DB_RENUMBER</a>), the count will be exact.  Otherwise, if the
DB_FAST_STAT flag is specified the count will be exact but will
include deleted and implicitly created records; if the
DB_FAST_STAT flag is not specified, the count will be exact and
will not include deleted or implicitly created records.</p>
<p>Returned if DB_FAST_STAT is set.</p>
<dt>u_int32_t bt_pagesize;<dd>Underlying database page size, in bytes.  Returned if
DB_FAST_STAT is set.
<dt>u_int32_t bt_minkey;<dd>The minimum keys per page.  Returned if DB_FAST_STAT is set.
<dt>u_int32_t bt_re_len;<dd>The length of fixed-length records.  Returned if DB_FAST_STAT
is set.
<dt>u_int32_t bt_re_pad;<dd>The padding byte value for fixed-length records.  Returned if
DB_FAST_STAT is set.
<dt>u_int32_t bt_levels;<dd>Number of levels in the database.
<dt>u_int32_t bt_int_pg;<dd>Number of database internal pages.
<dt>u_int32_t bt_leaf_pg;<dd>Number of database leaf pages.
<dt>u_int32_t bt_dup_pg;<dd>Number of database duplicate pages.
<dt>u_int32_t bt_over_pg;<dd>Number of database overflow pages.
<dt>u_int32_t bt_empty_pg;<dd>Number of empty database pages.
<dt>u_int32_t bt_free;<dd>Number of pages on the free list.
<dt>u_int32_t bt_int_pgfree;<dd>Number of bytes free in database internal pages.
<dt>u_int32_t bt_leaf_pgfree;<dd>Number of bytes free in database leaf pages.
<dt>u_int32_t bt_dup_pgfree;<dd>Number of bytes free in database duplicate pages.
<dt>u_int32_t bt_over_pgfree;<dd>Number of bytes free in database overflow pages.
</dl>
<h3>Queue Statistics</h3>
<p>In the case of a Queue database, the statistics are stored in a
structure of type DB_QUEUE_STAT.  The following fields will be filled
in:</p>
<dl compact>
<dt>u_int32_t qs_magic;<dd>Magic number that identifies the file as a Queue file.  Returned if
DB_FAST_STAT is set.
<dt>u_int32_t qs_version;<dd>The version of the Queue file type.  Returned if DB_FAST_STAT
is set.
<dt>u_int32_t qs_nkeys;<dd>The number of records in the database.  If DB_FAST_STAT was
specified the count will be the last saved value unless it has never
been calculated, in which case it will be 0.  Returned if
DB_FAST_STAT is set.
<dt>u_int32_t qs_ndata;<dd>The number of records in the database.  If DB_FAST_STAT was
specified the count will be the last saved value unless it has never
been calculated, in which case it will be 0.  Returned if
DB_FAST_STAT is set.
<dt>u_int32_t qs_pagesize;<dd>Underlying database page size, in bytes.  Returned if
DB_FAST_STAT is set.
<dt>u_int32_t qs_extentsize;<dd>Underlying database extent size, in pages.  Returned if
DB_FAST_STAT is set.
<dt>u_int32_t qs_pages;<dd>Number of pages in the database.
<dt>u_int32_t qs_re_len;<dd>The length of the records.  Returned if DB_FAST_STAT is set.
<dt>u_int32_t qs_re_pad;<dd>The padding byte value for the records.  Returned if
DB_FAST_STAT is set.
<dt>u_int32_t qs_pgfree;<dd>Number of bytes free in database pages.
<dt>u_int32_t qs_first_recno;<dd>First undeleted record in the database.  Returned if
DB_FAST_STAT is set.
<dt>u_int32_t qs_cur_recno;<dd>Next available record number.  Returned if DB_FAST_STAT is set.
</dl>
<h3>Errors</h3>
<p>The Db::stat method
may fail and throw
<a href="../api_cxx/except_class.html">DbException</a>,
encapsulating one of the following non-zero errors, or return one of
the following non-zero errors:</p>
<dl compact>
<dt>DB_REP_HANDLE_DEAD<dd>The database handle has been invalidated because a replication election
unrolled a committed transaction.
</dl>
<dl compact>
<dt>EINVAL<dd>An
invalid flag value or parameter was specified.
</dl>
<hr size=1 noshade>
<h3>Description: Db::stat_print</h3>
<p>The Db::stat_print method returns the
database statistical information, as described for the Db::stat method.
The information is printed to a specified output channel (see the
<a href="../api_cxx/env_set_msgfile.html">DbEnv::set_msgfile</a> method for more information), or passed to an
application callback function (see the <a href="../api_cxx/env_set_msgcall.html">DbEnv::set_msgcall</a> method for
more information).</p>
<p>The Db::stat_print method may not be called before the <a href="../api_cxx/db_open.html">Db::open</a> method has been
called.</p>
<p>The Db::stat_print method
either returns a non-zero error value
or throws an exception that encapsulates a non-zero error value on
failure, and returns 0 on success.
</p>
<h3>Parameters</h3>
<dl compact>
<dt><b>flags</b><dd>The <b>flags</b> parameter must be set to 0 or
the following value:
<dl compact>
<dt><a name="DB_STAT_ALL">DB_STAT_ALL</a><dd>Display all available information.
</dl>
</dl>
<hr size=1 noshade>
<h3>Class</h3>
<a href="../api_cxx/db_class.html">Db</a>
<h3>See Also</h3>
<a href="../api_cxx/db_list.html">Databases and Related Methods</a>
</tt>
<table width="100%"><tr><td><br></td><td align=right>
<a href="../api_cxx/api_core.html"><img src="../images/api.gif" alt="API"></a><a href="../ref/toc.html"><img src="../images/ref.gif" alt="Ref"></a>
</td></tr></table>
<p><font size=1><a href="../sleepycat/legal.html">Copyright (c) 1996-2004</a> <a href="http://www.sleepycat.com">Sleepycat Software, Inc.</a> - All rights reserved.</font>
</body>
</html>
 |