.Dd $Mdocdate$
.Dt SQLITE_STMTSTATUS_FULLSCAN_STEP 3
.Os
.Sh NAME
.Nm SQLITE_STMTSTATUS_FULLSCAN_STEP ,
.Nm SQLITE_STMTSTATUS_SORT ,
.Nm SQLITE_STMTSTATUS_AUTOINDEX ,
.Nm SQLITE_STMTSTATUS_VM_STEP ,
.Nm SQLITE_STMTSTATUS_REPREPARE ,
.Nm SQLITE_STMTSTATUS_RUN ,
.Nm SQLITE_STMTSTATUS_FILTER_MISS ,
.Nm SQLITE_STMTSTATUS_FILTER_HIT ,
.Nm SQLITE_STMTSTATUS_MEMUSED
.Nd status parameters for prepared statements
.Sh SYNOPSIS
.In sqlite3.h
.Fd #define SQLITE_STMTSTATUS_FULLSCAN_STEP
.Fd #define SQLITE_STMTSTATUS_SORT
.Fd #define SQLITE_STMTSTATUS_AUTOINDEX
.Fd #define SQLITE_STMTSTATUS_VM_STEP
.Fd #define SQLITE_STMTSTATUS_REPREPARE
.Fd #define SQLITE_STMTSTATUS_RUN
.Fd #define SQLITE_STMTSTATUS_FILTER_MISS
.Fd #define SQLITE_STMTSTATUS_FILTER_HIT
.Fd #define SQLITE_STMTSTATUS_MEMUSED
.Sh DESCRIPTION
These preprocessor macros define integer codes that name counter values
associated with the
.Fn sqlite3_stmt_status
interface.
The meanings of the various counters are as follows:
.Bl -tag -width Ds
.It SQLITE_STMTSTATUS_FULLSCAN_STEP
This is the number of times that SQLite has stepped forward in a table
as part of a full table scan.
Large numbers for this counter may indicate opportunities for performance
improvement through careful use of indices.
.It SQLITE_STMTSTATUS_SORT
This is the number of sort operations that have occurred.
A non-zero value in this counter may indicate an opportunity to improve
performance through careful use of indices.
.It SQLITE_STMTSTATUS_AUTOINDEX
This is the number of rows inserted into transient indices that were
created automatically in order to help joins run faster.
A non-zero value in this counter may indicate an opportunity to improve
performance by adding permanent indices that do not need to be reinitialized
each time the statement is run.
.It SQLITE_STMTSTATUS_VM_STEP
This is the number of virtual machine operations executed by the prepared
statement if that number is less than or equal to 2147483647.
The number of virtual machine operations can be used as a proxy for
the total work done by the prepared statement.
If the number of virtual machine operations exceeds 2147483647 then
the value returned by this statement status code is undefined.
.It SQLITE_STMTSTATUS_REPREPARE
This is the number of times that the prepare statement has been automatically
regenerated due to schema changes or changes to bound parameters
that might affect the query plan.
.It SQLITE_STMTSTATUS_RUN
This is the number of times that the prepared statement has been run.
A single "run" for the purposes of this counter is one or more calls
to
.Fn sqlite3_step
followed by a call to
.Fn sqlite3_reset .
The counter is incremented on the first
.Fn sqlite3_step
call of each cycle.
.It SQLITE_STMTSTATUS_FILTER_HIT  SQLITE_STMTSTATUS_FILTER_MISS
SQLITE_STMTSTATUS_FILTER_HIT is the number of times that a join step
was bypassed because a Bloom filter returned not-found.
The corresponding SQLITE_STMTSTATUS_FILTER_MISS value is the number
of times that the Bloom filter returned a find, and thus the join step
had to be processed as normal.
.It SQLITE_STMTSTATUS_MEMUSED
This is the approximate number of bytes of heap memory used to store
the prepared statement.
This value is not actually a counter, and so the resetFlg parameter
to sqlite3_stmt_status() is ignored when the opcode is SQLITE_STMTSTATUS_MEMUSED.
.El
.Pp
.Sh IMPLEMENTATION NOTES
These declarations were extracted from the
interface documentation at line 9238.
.Bd -literal
#define SQLITE_STMTSTATUS_FULLSCAN_STEP     1
#define SQLITE_STMTSTATUS_SORT              2
#define SQLITE_STMTSTATUS_AUTOINDEX         3
#define SQLITE_STMTSTATUS_VM_STEP           4
#define SQLITE_STMTSTATUS_REPREPARE         5
#define SQLITE_STMTSTATUS_RUN               6
#define SQLITE_STMTSTATUS_FILTER_MISS       7
#define SQLITE_STMTSTATUS_FILTER_HIT        8
#define SQLITE_STMTSTATUS_MEMUSED           99
.Ed
.Sh SEE ALSO
.Xr sqlite3_reset 3 ,
.Xr sqlite3_step 3 ,
.Xr sqlite3_stmt_status 3
