mirror of
https://github.com/postgres/postgres.git
synced 2026-02-27 03:40:28 -05:00
transaction, so as to avoid returning them out of the index AM. Saves repeated heap_fetch operations on frequently-updated rows. Also detect queries on unique keys (equality to all columns of a unique index), and don't bother continuing scan once we have found first match. Killing is implemented in the btree and hash AMs, but not yet in rtree or gist, because there isn't an equally convenient place to do it in those AMs (the outer amgetnext routine can't do it without re-pinning the index page). Did some small cleanup on APIs of HeapTupleSatisfies, heap_fetch, and index_insert to make this a little easier.
99 lines
3.1 KiB
C
99 lines
3.1 KiB
C
/*-------------------------------------------------------------------------
|
|
*
|
|
* relscan.h
|
|
* POSTGRES relation scan descriptor definitions.
|
|
*
|
|
*
|
|
* Portions Copyright (c) 1996-2001, PostgreSQL Global Development Group
|
|
* Portions Copyright (c) 1994, Regents of the University of California
|
|
*
|
|
* $Id: relscan.h,v 1.27 2002/05/24 18:57:56 tgl Exp $
|
|
*
|
|
*-------------------------------------------------------------------------
|
|
*/
|
|
#ifndef RELSCAN_H
|
|
#define RELSCAN_H
|
|
|
|
#include "utils/tqual.h"
|
|
|
|
|
|
typedef struct HeapScanDescData
|
|
{
|
|
/* scan parameters */
|
|
Relation rs_rd; /* heap relation descriptor */
|
|
Snapshot rs_snapshot; /* snapshot to see */
|
|
int rs_nkeys; /* number of scan keys */
|
|
ScanKey rs_key; /* array of scan key descriptors */
|
|
|
|
/* scan current state */
|
|
HeapTupleData rs_ctup; /* current tuple in scan, if any */
|
|
Buffer rs_cbuf; /* current buffer in scan, if any */
|
|
/* NB: if rs_cbuf is not InvalidBuffer, we hold a pin on that buffer */
|
|
ItemPointerData rs_mctid; /* marked scan position, if any */
|
|
|
|
PgStat_Info rs_pgstat_info; /* statistics collector hook */
|
|
} HeapScanDescData;
|
|
|
|
typedef HeapScanDescData *HeapScanDesc;
|
|
|
|
|
|
typedef struct IndexScanDescData
|
|
{
|
|
/* scan parameters */
|
|
Relation heapRelation; /* heap relation descriptor, or NULL */
|
|
Relation indexRelation; /* index relation descriptor */
|
|
Snapshot xs_snapshot; /* snapshot to see */
|
|
int numberOfKeys; /* number of scan keys */
|
|
ScanKey keyData; /* array of scan key descriptors */
|
|
|
|
/* signaling to index AM about killing index tuples */
|
|
bool kill_prior_tuple; /* last-returned tuple is dead */
|
|
bool ignore_killed_tuples; /* do not return killed entries */
|
|
|
|
/* set by index AM if scan keys satisfy index's uniqueness constraint */
|
|
bool keys_are_unique;
|
|
|
|
/* scan current state */
|
|
bool got_tuple; /* true after successful index_getnext */
|
|
void *opaque; /* access-method-specific info */
|
|
ItemPointerData currentItemData; /* current index pointer */
|
|
ItemPointerData currentMarkData; /* marked position, if any */
|
|
/*
|
|
* xs_ctup/xs_cbuf are valid after a successful index_getnext.
|
|
* After index_getnext_indexitem, xs_ctup.t_self contains the
|
|
* heap tuple TID from the index entry, but its other fields are
|
|
* not valid.
|
|
*/
|
|
HeapTupleData xs_ctup; /* current heap tuple, if any */
|
|
Buffer xs_cbuf; /* current heap buffer in scan, if any */
|
|
/* NB: if xs_cbuf is not InvalidBuffer, we hold a pin on that buffer */
|
|
|
|
FmgrInfo fn_getnext; /* cached lookup info for AM's getnext fn */
|
|
|
|
PgStat_Info xs_pgstat_info; /* statistics collector hook */
|
|
} IndexScanDescData;
|
|
|
|
typedef IndexScanDescData *IndexScanDesc;
|
|
|
|
|
|
/* ----------------
|
|
* IndexScanDescPtr is used in the executor where we have to
|
|
* keep track of several index scans when using several indices
|
|
* - cim 9/10/89
|
|
* ----------------
|
|
*/
|
|
typedef IndexScanDesc *IndexScanDescPtr;
|
|
|
|
/*
|
|
* HeapScanIsValid
|
|
* True iff the heap scan is valid.
|
|
*/
|
|
#define HeapScanIsValid(scan) PointerIsValid(scan)
|
|
|
|
/*
|
|
* IndexScanIsValid
|
|
* True iff the index scan is valid.
|
|
*/
|
|
#define IndexScanIsValid(scan) PointerIsValid(scan)
|
|
|
|
#endif /* RELSCAN_H */
|