PostgreSQL数据库手册学习之函数索引

王朝mssql·作者佚名  2008-05-18
窄屏简体版  字體: |||超大  

8.5. 函数索引

对于函数索引(functional index), 它是定义在一个函数的结果上的,这个函数对某一个表的一个或多 个字段进行操作。 函数索引可 以用于获得对那些基于函数调用结果数据的快速访问.

比如,做大小写无关比较的常用方法是使用函数 lower∶

SELECT * FROM test1 WHERE lower(col1) = 'value';

如果我们在 lower(column) 操作的结果上定义索引, 那么这个查询就可以使用索引∶

CREATE INDEX test1_lower_col1_idx ON test1 (lower(col1));

在索引定义里的函数可以接受更多个参数,但是这些参数 都必须是表的字段,而不能是常量.函数索引总是单字段 索引(也就是函数的结果),即使函数有多个输入域也如此; 不可能有包含函数调用的多字段索引.

小知识: 上面那段提到的约束可以很容易通过在索引定义中使用 客户化定义的函数,由该函数在内部计算任何我们需要的结果来绕开.

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航