Type: | integer |
Default: | 4096 (4MB) |
Min: | 64 (64kB) |
Max: | 2147483647 (2147483647kB) |
Unit: | KB |
Context: | user |
Restart: | false |
Sets the base maximum amount of memory to be used by a query operation (such as a sort or hash table) before writing to temporary disk files. If this value is specified without units, it is taken as kilobytes. The default value is four megabytes (4MB
). Note that a complex query might perform several sort and hash operations at the same time, with each operation generally being allowed to use as much memory as this value specifies before it starts to write data into temporary files. Also, several running sessions could be doing such operations concurrently. Therefore, the total memory used could be many times the value of work_mem
; it is necessary to keep this fact in mind when choosing the value. Sort operations are used for ORDER BY
, DISTINCT
, and merge joins. Hash tables are used in hash joins, hash-based aggregation, memoize nodes and hash-based processing of IN
subqueries.
Hash-based operations are generally more sensitive to memory availability than equivalent sort-based operations. The memory limit for a hash table is computed by multiplying work_mem
by hash_mem_multiplier. This makes it possible for hash-based operations to use an amount of memory that exceeds the usual work_mem
base amount.
Recommendations
On StackOverflow
On pgsql-hackers
- Re: Lowering the minimum value for maintenance_work_mem
- Proposal: "query_work_mem" GUC, to distribute working memory to the query's individual operators
- Re: Add mention of execution time memory for enable_partitionwise_* GUCs
- Re: Adjusting hash join memory limit to handle batch explosion
- Re: Add the ability to limit the amount of memory that can be allocated to backends.