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

相关文章

PostgreSQL 默认隔离级别的设置

《PostgreSQL默认隔离级别的设置》PostgreSQL的默认事务隔离级别是读已提交,这是其事务处理系统的基础行为模式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一 默认隔离级别概述1.1 默认设置1.2 各版本一致性二 读已提交的特性2.1 行为特征2.2

PostgreSQL中MVCC 机制的实现

《PostgreSQL中MVCC机制的实现》本文主要介绍了PostgreSQL中MVCC机制的实现,通过多版本数据存储、快照隔离和事务ID管理实现高并发读写,具有一定的参考价值,感兴趣的可以了解一下... 目录一 MVCC 基本原理python1.1 MVCC 核心概念1.2 与传统锁机制对比二 Postg

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名

SQL Server数据库死锁处理超详细攻略

《SQLServer数据库死锁处理超详细攻略》SQLServer作为主流数据库管理系统,在高并发场景下可能面临死锁问题,影响系统性能和稳定性,这篇文章主要给大家介绍了关于SQLServer数据库死... 目录一、引言二、查询 Sqlserver 中造成死锁的 SPID三、用内置函数查询执行信息1. sp_w

Python中help()和dir()函数的使用

《Python中help()和dir()函数的使用》我们经常需要查看某个对象(如模块、类、函数等)的属性和方法,Python提供了两个内置函数help()和dir(),它们可以帮助我们快速了解代... 目录1. 引言2. help() 函数2.1 作用2.2 使用方法2.3 示例(1) 查看内置函数的帮助(

Python中使用uv创建环境及原理举例详解

《Python中使用uv创建环境及原理举例详解》uv是Astral团队开发的高性能Python工具,整合包管理、虚拟环境、Python版本控制等功能,:本文主要介绍Python中使用uv创建环境及... 目录一、uv工具简介核心特点:二、安装uv1. 通过pip安装2. 通过脚本安装验证安装:配置镜像源(可

C++ 函数 strftime 和时间格式示例详解

《C++函数strftime和时间格式示例详解》strftime是C/C++标准库中用于格式化日期和时间的函数,定义在ctime头文件中,它将tm结构体中的时间信息转换为指定格式的字符串,是处理... 目录C++ 函数 strftipythonme 详解一、函数原型二、功能描述三、格式字符串说明四、返回值五

Java中实现线程的创建和启动的方法

《Java中实现线程的创建和启动的方法》在Java中,实现线程的创建和启动是两个不同但紧密相关的概念,理解为什么要启动线程(调用start()方法)而非直接调用run()方法,是掌握多线程编程的关键,... 目录1. 线程的生命周期2. start() vs run() 的本质区别3. 为什么必须通过 st

Python中bisect_left 函数实现高效插入与有序列表管理

《Python中bisect_left函数实现高效插入与有序列表管理》Python的bisect_left函数通过二分查找高效定位有序列表插入位置,与bisect_right的区别在于处理重复元素时... 目录一、bisect_left 基本介绍1.1 函数定义1.2 核心功能二、bisect_left 与

java中BigDecimal里面的subtract函数介绍及实现方法

《java中BigDecimal里面的subtract函数介绍及实现方法》在Java中实现减法操作需要根据数据类型选择不同方法,主要分为数值型减法和字符串减法两种场景,本文给大家介绍java中BigD... 目录Java中BigDecimal里面的subtract函数的意思?一、数值型减法(高精度计算)1.