Update copyright for 2022
[pgsql.git] / src / include / catalog / pg_statistic_ext.h
blobb8520ba923b475fc4e48a2988291488049600bfc
1 /*-------------------------------------------------------------------------
3 * pg_statistic_ext.h
4 * definition of the "extended statistics" system catalog
5 * (pg_statistic_ext)
7 * Note that pg_statistic_ext contains the definitions of extended statistics
8 * objects, created by CREATE STATISTICS, but not the actual statistical data,
9 * created by running ANALYZE.
11 * Portions Copyright (c) 1996-2022, PostgreSQL Global Development Group
12 * Portions Copyright (c) 1994, Regents of the University of California
14 * src/include/catalog/pg_statistic_ext.h
16 * NOTES
17 * The Catalog.pm module reads this file and derives schema
18 * information.
20 *-------------------------------------------------------------------------
22 #ifndef PG_STATISTIC_EXT_H
23 #define PG_STATISTIC_EXT_H
25 #include "catalog/genbki.h"
26 #include "catalog/pg_statistic_ext_d.h"
28 /* ----------------
29 * pg_statistic_ext definition. cpp turns this into
30 * typedef struct FormData_pg_statistic_ext
31 * ----------------
33 CATALOG(pg_statistic_ext,3381,StatisticExtRelationId)
35 Oid oid; /* oid */
37 Oid stxrelid BKI_LOOKUP(pg_class); /* relation containing
38 * attributes */
40 /* These two fields form the unique key for the entry: */
41 NameData stxname; /* statistics object name */
42 Oid stxnamespace BKI_LOOKUP(pg_namespace); /* OID of statistics
43 * object's namespace */
45 Oid stxowner BKI_LOOKUP(pg_authid); /* statistics object's owner */
46 int32 stxstattarget BKI_DEFAULT(-1); /* statistics target */
49 * variable-length fields start here, but we allow direct access to
50 * stxkeys
52 int2vector stxkeys BKI_FORCE_NOT_NULL; /* array of column keys */
54 #ifdef CATALOG_VARLEN
55 char stxkind[1] BKI_FORCE_NOT_NULL; /* statistics kinds requested
56 * to build */
57 pg_node_tree stxexprs; /* A list of expression trees for stats
58 * attributes that are not simple column
59 * references. */
60 #endif
62 } FormData_pg_statistic_ext;
64 /* ----------------
65 * Form_pg_statistic_ext corresponds to a pointer to a tuple with
66 * the format of pg_statistic_ext relation.
67 * ----------------
69 typedef FormData_pg_statistic_ext *Form_pg_statistic_ext;
71 DECLARE_TOAST(pg_statistic_ext, 3439, 3440);
73 DECLARE_UNIQUE_INDEX_PKEY(pg_statistic_ext_oid_index, 3380, StatisticExtOidIndexId, on pg_statistic_ext using btree(oid oid_ops));
74 DECLARE_UNIQUE_INDEX(pg_statistic_ext_name_index, 3997, StatisticExtNameIndexId, on pg_statistic_ext using btree(stxname name_ops, stxnamespace oid_ops));
75 DECLARE_INDEX(pg_statistic_ext_relid_index, 3379, StatisticExtRelidIndexId, on pg_statistic_ext using btree(stxrelid oid_ops));
77 DECLARE_ARRAY_FOREIGN_KEY((stxrelid, stxkeys), pg_attribute, (attrelid, attnum));
79 #ifdef EXPOSE_TO_CLIENT_CODE
81 #define STATS_EXT_NDISTINCT 'd'
82 #define STATS_EXT_DEPENDENCIES 'f'
83 #define STATS_EXT_MCV 'm'
84 #define STATS_EXT_EXPRESSIONS 'e'
86 #endif /* EXPOSE_TO_CLIENT_CODE */
88 #endif /* PG_STATISTIC_EXT_H */