我一直在从事一个工作项目,并意识到我必须在几个查询的 WHERE 子句中调用一个函数。性能并不完全糟糕,但我很想改进它。所以我查看了文档中提到的索引:
索引字段可以是根据表格行的一个或多个列的值计算的表达式。
惊人的。所以我尝试创建一个索引:
CREATE INDEX idx_foo ON foo_table (stable_function(foo_column));
并收到一个错误:
错误:索引表达式中的函数必须标记为 IMMUTABLE
然后我读到了关于稳定波动率的函数波动率类别:
特别是,在索引扫描条件中使用包含此类函数的表达式是安全的。
基于措辞“索引扫描条件”,我猜这并不意味着实际的索引。那么这是什么意思呢?是否可以在索引中使用稳定的函数?还是我们必须一路走下去,确保它可以作为一个不可变的函数工作?
我们正在使用 Postgres v9.0.1。