postgresql immutable_PostgreSQL 之函数索引

本文探讨了PostgreSQL中函数索引的应用,强调函数必须是immutable的,即输入参数不变时结果恒定。通过实例展示了如何使用函数索引提高查询效率,并通过成绩查询的例子说明了当数据变化时,未更新的函数索引可能导致错误结果。最后提醒,确保在使用函数索引时,正确处理数据变更以保持索引准确性。
摘要由CSDN通过智能技术生成

640?wx_fmt=png

PostgreSQL支持函数索引,但函数必须是immutable的,变量不变时,索引本身不会变化的,所以函数当输入参数不变时,结果必须是永恒不变的。

做个实验,一次其中考试的成绩,有一张表存储学生信息,另一张表存储考试成绩,我们通过平均成绩搜索符合成绩的学生,可以使用索引吗?

使用函数索引,可以的。但是前提是,输入学号,得到平均成绩不能变化(当然成绩是不会变化的),不然数据变化,但索引不会刷新,则搜索的数据与实际不符。

例子: 

create extension btree_gist;

学生信息表

create table t_user (id int8 primary key, name text);

成绩表

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值