summaryrefslogtreecommitdiff
path: root/contrib/pg_stat_statements/pg_stat_statements.sql.in
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2010-05-27 15:59:15 +0000
committerTom Lane <tgl@sss.pgh.pa.us>2010-05-27 15:59:15 +0000
commit8ca22ee11cdb74e84ae43e81b7a55865452b0ef4 (patch)
tree28f1f424f2f06ce977603739f88d0c916b1ad351 /contrib/pg_stat_statements/pg_stat_statements.sql.in
parentbb6e270ae31e25d8a7d43056cffadfc061f61a12 (diff)
Make CREATE INDEX run expression preprocessing on a proposed index expression
before it checks whether the expression is immutable. This covers two cases that were previously handled poorly: 1. SQL function inlining could reduce the apparent volatility of the expression, allowing an expression to be accepted where it previously would not have been. As an example, polymorphic functions must be marked with the worst-case volatility they have for any argument type, but for specific argument types they might not be so volatile, so indexing could be allowed. (Since the planner will refuse to inline functions in cases where the apparent volatility of the expression would increase, this won't break any cases that were accepted before.) 2. A nominally immutable function could have default arguments that are volatile expressions. In such a case insertion of the defaults will increase both the apparent and actual volatility of the expression, so it is *necessary* to check this before allowing the expression to be indexed. Back-patch to 8.4, where default arguments were introduced.
Diffstat (limited to 'contrib/pg_stat_statements/pg_stat_statements.sql.in')
0 files changed, 0 insertions, 0 deletions