# pg_aggregate The `pg_aggregate` table stores information about aggregate functions. An aggregate function is a function that operates on a set of values (typically one column from each row that matches a query condition) and returns a single value computed from all these values. Typical aggregate functions are `sum`, `count`, and `max`. Each entry in `pg_aggregate` is an extension of an entry in `pg_proc`. The `pg_proc` entry carries the aggregate’s name, input and output data types, and other information that is similar to ordinary functions. Table 1. `pg_catalog.pg_aggregate` | column | type | references | description | | :--------------- | :------ | :-------------- | :----------------------------------------------------------- | | `aggfnoid` | regproc | pg_proc.oid | Aggregate function OID | | `aggtransfn` | regproc | pg_proc.oid | Transition function OID | | `agginvtransfn` | regproc | pg_proc.oid | The OID in pg_proc of the inverse function of *aggtransfn* | | `aggprelimfn` | regproc | | Preliminary function OID (zero if none) | | `agginvprelimfn` | regproc | pg_proc.oid | The OID in pg_proc of the inverse function of aggprelimfn | | `aggfinalfn` | regproc | pg_proc.oid | Final function OID (zero if none) | | `aggsortop` | oid | pg_operator.oid | Associated sort operator OID (zero if none) | | `aggtranstype` | oid | pg_type.oid | Data type of the aggregate function’s internal transition (state) data | | `agginitval` | text | | The initial value of the transition state. This is a text field containing the initial value in its external string representation. If this field is NULL, the transition state value starts out NULL | | `aggordered` | boolean | | If `true`, the aggregate is defined as `ORDERED`. |