Commit 2fe6336e authored by Robert Haas's avatar Robert Haas

Avoid creating a TOAST table for a partitioned table.

It's useless.

Amit Langote

Discussion: http://postgr.es/m/b4c9dee6-d134-49b8-79c4-07fbd7c3b898@lab.ntt.co.jp
parent 8a8c4f3b
...@@ -397,6 +397,7 @@ create_toast_table(Relation rel, Oid toastOid, Oid toastIndexOid, ...@@ -397,6 +397,7 @@ create_toast_table(Relation rel, Oid toastOid, Oid toastIndexOid,
* (1) there are any toastable attributes, and (2) the maximum length * (1) there are any toastable attributes, and (2) the maximum length
* of a tuple could exceed TOAST_TUPLE_THRESHOLD. (We don't want to * of a tuple could exceed TOAST_TUPLE_THRESHOLD. (We don't want to
* create a toast table for something like "f1 varchar(20)".) * create a toast table for something like "f1 varchar(20)".)
* No need to create a TOAST table for partitioned tables.
*/ */
static bool static bool
needs_toast_table(Relation rel) needs_toast_table(Relation rel)
...@@ -408,6 +409,9 @@ needs_toast_table(Relation rel) ...@@ -408,6 +409,9 @@ needs_toast_table(Relation rel)
int32 tuple_length; int32 tuple_length;
int i; int i;
if (rel->rd_rel->relkind == RELKIND_PARTITIONED_TABLE)
return false;
tupdesc = rel->rd_att; tupdesc = rel->rd_att;
for (i = 0; i < tupdesc->natts; i++) for (i = 0; i < tupdesc->natts; i++)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment