mirror of
https://git.postgresql.org/git/postgresql.git
synced 2025-01-12 18:34:36 +08:00
Update comments
Various places wanted to point out that tuple descriptors don't contain the variable-length fields of pg_attribute. This started when attacl was added, but more fields have been added since, and these comments haven't been kept up to date consistently. Reword so that the purpose is clearer and we don't have to keep updating them.
This commit is contained in:
parent
99e4d24a9d
commit
36cb5e7c51
@ -630,7 +630,7 @@ TupleDescInitEntry(TupleDesc desc,
|
|||||||
att->attisdropped = false;
|
att->attisdropped = false;
|
||||||
att->attislocal = true;
|
att->attislocal = true;
|
||||||
att->attinhcount = 0;
|
att->attinhcount = 0;
|
||||||
/* attacl, attoptions and attfdwoptions are not present in tupledescs */
|
/* variable-length fields are not present in tupledescs */
|
||||||
|
|
||||||
tuple = SearchSysCache1(TYPEOID, ObjectIdGetDatum(oidtypeid));
|
tuple = SearchSysCache1(TYPEOID, ObjectIdGetDatum(oidtypeid));
|
||||||
if (!HeapTupleIsValid(tuple))
|
if (!HeapTupleIsValid(tuple))
|
||||||
@ -691,7 +691,7 @@ TupleDescInitBuiltinEntry(TupleDesc desc,
|
|||||||
att->attisdropped = false;
|
att->attisdropped = false;
|
||||||
att->attislocal = true;
|
att->attislocal = true;
|
||||||
att->attinhcount = 0;
|
att->attinhcount = 0;
|
||||||
/* attacl, attoptions and attfdwoptions are not present in tupledescs */
|
/* variable-length fields are not present in tupledescs */
|
||||||
|
|
||||||
att->atttypid = oidtypeid;
|
att->atttypid = oidtypeid;
|
||||||
|
|
||||||
|
@ -723,9 +723,10 @@ CheckAttributeType(const char *attname,
|
|||||||
* Construct and insert a set of tuples in pg_attribute.
|
* Construct and insert a set of tuples in pg_attribute.
|
||||||
*
|
*
|
||||||
* Caller has already opened and locked pg_attribute. tupdesc contains the
|
* Caller has already opened and locked pg_attribute. tupdesc contains the
|
||||||
* attributes to insert. attcacheoff is always initialized to -1, attacl,
|
* attributes to insert. attcacheoff is always initialized to -1. attoptions
|
||||||
* attfdwoptions and attmissingval are always initialized to NULL. attoptions
|
* supplies the values for the attoptions fields and must contain the same
|
||||||
* must contain the same number of elements as tupdesc, or be NULL.
|
* number of elements as tupdesc or be NULL. The other variable-length fields
|
||||||
|
* of pg_attribute are always initialized to null values.
|
||||||
*
|
*
|
||||||
* indstate is the index state for CatalogTupleInsertWithInfo. It can be
|
* indstate is the index state for CatalogTupleInsertWithInfo. It can be
|
||||||
* passed as NULL, in which case we'll fetch the necessary info. (Don't do
|
* passed as NULL, in which case we'll fetch the necessary info. (Don't do
|
||||||
|
@ -6734,7 +6734,10 @@ ATExecAddColumn(List **wqueue, AlteredTableInfo *tab, Relation rel,
|
|||||||
list_make1_oid(rel->rd_rel->reltype),
|
list_make1_oid(rel->rd_rel->reltype),
|
||||||
0);
|
0);
|
||||||
|
|
||||||
/* construct new attribute's pg_attribute entry */
|
/*
|
||||||
|
* Construct new attribute's pg_attribute entry. (Variable-length fields
|
||||||
|
* are handled by InsertPgAttributeTuples().)
|
||||||
|
*/
|
||||||
attribute.attrelid = myrelid;
|
attribute.attrelid = myrelid;
|
||||||
namestrcpy(&(attribute.attname), colDef->colname);
|
namestrcpy(&(attribute.attname), colDef->colname);
|
||||||
attribute.atttypid = typeOid;
|
attribute.atttypid = typeOid;
|
||||||
@ -6758,8 +6761,6 @@ ATExecAddColumn(List **wqueue, AlteredTableInfo *tab, Relation rel,
|
|||||||
attribute.attinhcount = colDef->inhcount;
|
attribute.attinhcount = colDef->inhcount;
|
||||||
attribute.attcollation = collOid;
|
attribute.attcollation = collOid;
|
||||||
|
|
||||||
/* attribute.attacl is handled by InsertPgAttributeTuples() */
|
|
||||||
|
|
||||||
ReleaseSysCache(typeTuple);
|
ReleaseSysCache(typeTuple);
|
||||||
|
|
||||||
tupdesc = CreateTupleDesc(lengthof(aattr), (FormData_pg_attribute **) &aattr);
|
tupdesc = CreateTupleDesc(lengthof(aattr), (FormData_pg_attribute **) &aattr);
|
||||||
|
Loading…
Reference in New Issue
Block a user