PostgreSQL数据库内核(五):创建内置函数pg_test_function

2024-08-22 15:04

本文主要是介绍PostgreSQL数据库内核(五):创建内置函数pg_test_function,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

函数定义

函数注册/声明

函数验证


一般接触到的普通的web段上层应用都是基于http的REST传递数据,数据库则使用安全可靠的tcp长连接进行数据交互,在拓展pg功能时候,有几个交互验证的方式:

  1. 内置sql函数(如字符串处理、数值计算、日期时间处理、类型转换函数);
  2. 命令行(checkpoint),

postgres=# SELECT trim(both ' ' FROM ' Hello World ');btrim
-------------Hello World
(1 row)postgres=# checkpoint ;
CHECKPOINT

内置函数在广义上是全局共享/不区分权限的,本次增加1个pg_test_function()函数,入参是1个整型的变量,输出2倍数;

函数定义

服用 src/backend/utils/adt/ 目录下其他.c文件(如datum.c),增加 pg_test_function这个函数的定义,可以参考同类函数定义方式:

Datum
pg_test_function(PG_FUNCTION_ARGS)
{int32 input = PG_GETARG_INT32(0);int32 result;result = input * 2;PG_RETURN_INT32(result);
}

函数注册/声明

在 src/include/catalog/pg_proc.dat 文件中添加新函数的元数据此文件用于定义函数的元数据,如函数名、参数类型、返回类型等。

{ oid => '8888', descr => 'pg_test_function',proname => 'pg_test_function',prorettype => 'int4', proargtypes => 'int4',prosrc => 'pg_test_function' },

在 src/include/catalog/pg_proc.dat 文件中添加新函数声明:

extern Datum pg_test_function(PG_FUNCTION_ARGS);

函数验证

修改代码后,重新执行编译:

cd /home/yzg/postgresql-14.5
make clean
CFLAGS=-O0 ./configure --prefix=/usr/local/pgsql --enable-debug
make
make install
cp -R /usr/local/pgsql /home/postgres/
chown -R postgres:postgres /home/postgres/pgsql
# 切换用户
su - postgres
cd ~/pgsql/bin
# 初始化postgresql并启动
./initdb -D ~/data
./pg_ctl start -D ~/data

直接执行函数:


postgres=# select pg_test_function(10);pg_test_function
------------------20
(1 row)

本例是个简单的内置函数增加方法与测试,在扩展/新增功能点时候内置函数可能是对用户暴露的调用方法,根据实际的业务需求应该还有对应的逻辑;

这篇关于PostgreSQL数据库内核(五):创建内置函数pg_test_function的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1096607

相关文章

C++中assign函数的使用

《C++中assign函数的使用》在C++标准模板库中,std::list等容器都提供了assign成员函数,它比操作符更灵活,支持多种初始化方式,下面就来介绍一下assign的用法,具有一定的参考价... 目录​1.assign的基本功能​​语法​2. 具体用法示例​​​(1) 填充n个相同值​​(2)

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

IntelliJ IDEA2025创建SpringBoot项目的实现步骤

《IntelliJIDEA2025创建SpringBoot项目的实现步骤》本文主要介绍了IntelliJIDEA2025创建SpringBoot项目的实现步骤,文中通过示例代码介绍的非常详细,对大家... 目录一、创建 Spring Boot 项目1. 新建项目2. 基础配置3. 选择依赖4. 生成项目5.

PostgreSQL中rank()窗口函数实用指南与示例

《PostgreSQL中rank()窗口函数实用指南与示例》在数据分析和数据库管理中,经常需要对数据进行排名操作,PostgreSQL提供了强大的窗口函数rank(),可以方便地对结果集中的行进行排名... 目录一、rank()函数简介二、基础示例:部门内员工薪资排名示例数据排名查询三、高级应用示例1. 每

Linux线程之线程的创建、属性、回收、退出、取消方式

《Linux线程之线程的创建、属性、回收、退出、取消方式》文章总结了线程管理核心知识:线程号唯一、创建方式、属性设置(如分离状态与栈大小)、回收机制(join/detach)、退出方法(返回/pthr... 目录1. 线程号2. 线程的创建3. 线程属性4. 线程的回收5. 线程的退出6. 线程的取消7.

SQL server数据库如何下载和安装

《SQLserver数据库如何下载和安装》本文指导如何下载安装SQLServer2022评估版及SSMS工具,涵盖安装配置、连接字符串设置、C#连接数据库方法和安全注意事项,如混合验证、参数化查... 目录第一步:打开官网下载对应文件第二步:程序安装配置第三部:安装工具SQL Server Manageme

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.

全面掌握 SQL 中的 DATEDIFF函数及用法最佳实践

《全面掌握SQL中的DATEDIFF函数及用法最佳实践》本文解析DATEDIFF在不同数据库中的差异,强调其边界计算原理,探讨应用场景及陷阱,推荐根据需求选择TIMESTAMPDIFF或inte... 目录1. 核心概念:DATEDIFF 究竟在计算什么?2. 主流数据库中的 DATEDIFF 实现2.1

MySQL中的LENGTH()函数用法详解与实例分析

《MySQL中的LENGTH()函数用法详解与实例分析》MySQLLENGTH()函数用于计算字符串的字节长度,区别于CHAR_LENGTH()的字符长度,适用于多字节字符集(如UTF-8)的数据验证... 目录1. LENGTH()函数的基本语法2. LENGTH()函数的返回值2.1 示例1:计算字符串

创建Java keystore文件的完整指南及详细步骤

《创建Javakeystore文件的完整指南及详细步骤》本文详解Java中keystore的创建与配置,涵盖私钥管理、自签名与CA证书生成、SSL/TLS应用,强调安全存储及验证机制,确保通信加密和... 目录1. 秘密键(私钥)的理解与管理私钥的定义与重要性私钥的管理策略私钥的生成与存储2. 证书的创建与