20、PostgreSQL PL/pgSQL编程全解析

PostgreSQL PL/pgSQL编程全解析

1. 函数配置相关参数

函数配置相关参数是设置参数,可用于确定执行操作所需的资源(如内存量 work_mem ),或者确定执行行为(如禁用顺序扫描或嵌套循环连接)。只有具有用户上下文的参数才能使用。

SET 子句会在函数进入时将指定的设置参数设置为指定值,函数退出时,该设置参数值会重置为默认值。参数配置设置可以为整个函数显式设置,也可以在函数内部局部覆盖,还可以使用 FROM CURRENT 子句从会话设置继承值。

这些配置参数常用于在资源有限、遗留代码、设计不佳、统计估计错误等情况下调整函数性能。例如,假设一个函数由于数据库规范化而表现不佳,重构数据库可能成本较高。为解决此问题,可以通过启用或禁用某些设置来更改执行计划,示例如下:

car_portal=# SET enable_seqscan TO OFF;
SET
car_portal=# CREATE OR REPLACE FUNCTION configuration_test () RETURNS 
VOID AS
$$
BEGIN
RAISE NOTICE 'Current session enable_seqscan value: %', (SELECT setting 
FROM pg_settings WHERE name ='enable_seqscan')::text;
RAISE NOTICE 'Function work_mem: %', (SELECT setting FROM pg_set
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值