对PostgreSQL SPI_finish的理解

本文涉及的产品
云原生数据库 PolarDB MySQL 版,Serverless 5000PCU 100GB
简介:

参考这个例子:

http://www.postgresql.org/docs/9.1/static/spi-examples.html

如果我们在 src/backend/executor/spi.c 的  SPI_finish 函数处进行调试(增加打印 SPI_finish called)可以发现,

如果不在SPI 程序中调用 SPI_finish,其实会有问题。

启动PostgreSQL:

[root@localhost ~]# su - postgres
[postgres@localhost ~]$ cd /usr/local/pgsql/bin
[postgres@localhost bin]$ ./postgres -D /usr/local/pgsql/data
LOG:  database system was shut down at 2012-10-29 09:27:55 CST
LOG:  autovacuum launcher started
LOG:  database system is ready to accept connections

调用 execq函数:

复制代码
postgres=# create or replace function execq(text,integer) returns integer as '/usr/local/pgsql/lib/execq.so','execq' language c strict;
CREATE FUNCTION
postgres=# select execq('select * from testtab',10);
INFO:  EXECQ:  1 | 12345 
WARNING:  transaction left non-empty SPI stack
HINT:  Check for missing "SPI_finish" calls.
 execq 
-------
     1
(1 row)

postgres=# 
复制代码




相关实践学习
使用PolarDB和ECS搭建门户网站
本场景主要介绍基于PolarDB和ECS实现搭建门户网站。
阿里云数据库产品家族及特性
阿里云智能数据库产品团队一直致力于不断健全产品体系,提升产品性能,打磨产品功能,从而帮助客户实现更加极致的弹性能力、具备更强的扩展能力、并利用云设施进一步降低企业成本。以云原生+分布式为核心技术抓手,打造以自研的在线事务型(OLTP)数据库Polar DB和在线分析型(OLAP)数据库Analytic DB为代表的新一代企业级云原生数据库产品体系, 结合NoSQL数据库、数据库生态工具、云原生智能化数据库管控平台,为阿里巴巴经济体以及各个行业的企业客户和开发者提供从公共云到混合云再到私有云的完整解决方案,提供基于云基础设施进行数据从处理、到存储、再到计算与分析的一体化解决方案。本节课带你了解阿里云数据库产品家族及特性。
目录
相关文章
|
4月前
|
关系型数据库 数据库 PostgreSQL
postgresql|数据库|启动数据库时报错:FATAL: could not map anonymous shared memory的解决
postgresql|数据库|启动数据库时报错:FATAL: could not map anonymous shared memory的解决
46 1
|
4月前
|
监控 关系型数据库 Java
SpringBoot【集成 01】Druid+Dynamic+Greenplum(实际上用的是PostgreSQL的驱动)及 dbType not support 问题处理(附hikari相关配置)
SpringBoot【集成 01】Druid+Dynamic+Greenplum(实际上用的是PostgreSQL的驱动)及 dbType not support 问题处理(附hikari相关配置)
73 0
|
4月前
|
SQL 监控 关系型数据库
postgresql|数据库|插件学习(一)---postgresql-12的内置插件pg_stat_statements的启用和使用
postgresql|数据库|插件学习(一)---postgresql-12的内置插件pg_stat_statements的启用和使用
83 0
|
9月前
|
关系型数据库 PostgreSQL
PostgreSQL pg_ctl start超时分析
PostgreSQL pg_ctl start超时分析
84 0
|
SQL 存储 缓存
17PostgreSQL shared nothing分布式用法讲解|学习笔记(一 )
快速学习17PostgreSQL shared nothing分布式用法讲解
186 0
17PostgreSQL shared nothing分布式用法讲解|学习笔记(一 )
|
SQL 关系型数据库 数据库
|
关系型数据库 PostgreSQL SQL
|
关系型数据库 PostgreSQL
|
关系型数据库 PostgreSQL
|
关系型数据库 网络安全 安全