pg_opclass.h 3.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. /*-------------------------------------------------------------------------
  2. *
  3. * pg_opclass.h
  4. * definition of the "operator class" system catalog (pg_opclass)
  5. *
  6. * The primary key for this table is <opcmethod, opcname, opcnamespace> ---
  7. * that is, there is a row for each valid combination of opclass name and
  8. * index access method type. This row specifies the expected input data type
  9. * for the opclass (the type of the heap column, or the expression output type
  10. * in the case of an index expression). Note that types binary-coercible to
  11. * the specified type will be accepted too.
  12. *
  13. * For a given <opcmethod, opcintype> pair, there can be at most one row that
  14. * has opcdefault = true; this row is the default opclass for such data in
  15. * such an index. (This is not currently enforced by an index, because we
  16. * don't support partial indexes on system catalogs.)
  17. *
  18. * Normally opckeytype = InvalidOid (zero), indicating that the data stored
  19. * in the index is the same as the data in the indexed column. If opckeytype
  20. * is nonzero then it indicates that a conversion step is needed to produce
  21. * the stored index data, which will be of type opckeytype (which might be
  22. * the same or different from the input datatype). Performing such a
  23. * conversion is the responsibility of the index access method --- not all
  24. * AMs support this.
  25. *
  26. *
  27. * Portions Copyright (c) 1996-2022, PostgreSQL Global Development Group
  28. * Portions Copyright (c) 1994, Regents of the University of California
  29. *
  30. * src/include/catalog/pg_opclass.h
  31. *
  32. * NOTES
  33. * The Catalog.pm module reads this file and derives schema
  34. * information.
  35. *
  36. *-------------------------------------------------------------------------
  37. */
  38. #ifndef PG_OPCLASS_H
  39. #define PG_OPCLASS_H
  40. #include "catalog/genbki.h"
  41. #include "catalog/pg_opclass_d.h"
  42. /* ----------------
  43. * pg_opclass definition. cpp turns this into
  44. * typedef struct FormData_pg_opclass
  45. * ----------------
  46. */
  47. CATALOG(pg_opclass,2616,OperatorClassRelationId)
  48. {
  49. Oid oid; /* oid */
  50. /* index access method opclass is for */
  51. Oid opcmethod BKI_LOOKUP(pg_am);
  52. /* name of this opclass */
  53. NameData opcname;
  54. /* namespace of this opclass */
  55. Oid opcnamespace BKI_DEFAULT(pg_catalog) BKI_LOOKUP(pg_namespace);
  56. /* opclass owner */
  57. Oid opcowner BKI_DEFAULT(POSTGRES) BKI_LOOKUP(pg_authid);
  58. /* containing operator family */
  59. Oid opcfamily BKI_LOOKUP(pg_opfamily);
  60. /* type of data indexed by opclass */
  61. Oid opcintype BKI_LOOKUP(pg_type);
  62. /* T if opclass is default for opcintype */
  63. bool opcdefault BKI_DEFAULT(t);
  64. /* type of data in index, or InvalidOid if same as input column type */
  65. Oid opckeytype BKI_DEFAULT(0) BKI_LOOKUP_OPT(pg_type);
  66. } FormData_pg_opclass;
  67. /* ----------------
  68. * Form_pg_opclass corresponds to a pointer to a tuple with
  69. * the format of pg_opclass relation.
  70. * ----------------
  71. */
  72. typedef FormData_pg_opclass *Form_pg_opclass;
  73. DECLARE_UNIQUE_INDEX(pg_opclass_am_name_nsp_index, 2686, OpclassAmNameNspIndexId, on pg_opclass using btree(opcmethod oid_ops, opcname name_ops, opcnamespace oid_ops));
  74. DECLARE_UNIQUE_INDEX_PKEY(pg_opclass_oid_index, 2687, OpclassOidIndexId, on pg_opclass using btree(oid oid_ops));
  75. #endif /* PG_OPCLASS_H */