PostgreSQL-UDF用户自定义函数-扩展插件
目录
- PostgreSQL-UDF用户自定义函数-扩展插件
- 零、前置条件
- 一、创建 .c 和 .sql 文件
- 创建.c文件
- 创建.sql文件
- 二、创建 .control 和 Makefile 文件
- 创建 .control 文件
- 创建 Makefile 文件
- 三、编译 & 链接
- 四、psql(或者其他PG backend)中创建扩展
PostgreSQL-UDF用户自定义函数-扩展插件
零、前置条件
- ggc
- postgresql
一、创建 .c 和 .sql 文件
创建.c文件
- 进入PG源码的
contib/
目录下面,这个目录下面都是用于PG进行功能扩展的插件。 - 创建我们的插件(UDF同义词:插件;扩展;用户自定义函数)目录
demo/
。 - 在我们的插件目录下创建
.c
和.sql
文件,后续第二步中还会创建用于编译和链接的Makefile
文件和.control
文件。
[root@localhost ~]# cd /root/pgsoft/postgresql-15.3/contrib/
[root@localhost contrib]# mkdir demo
[root@localhost contrib]# cd demo
# 创建.c文件
[root@localhost demo]# vim demo.c
- UDF函数的
.c
文件写法见该链接第二步。 .c
文件内容如下:
#include "postgres.h"
#include "fmgr.h"#ifdef PG_MODULE_MAGIC
PG_MODULE_MAGIC;
#endifPG_FUNCTION_INFO_V1(my_sum); //PG中需要使用PG_FUNCTION_INFO_V1()来声明函数名Datum my_sum(PG_FUNCTION_ARGS); Datum my_sum(PG_FUNCTION_ARGS){ //定义函数体,这里定义的函数体功能是返回传参的两整型数相加的结果int32 a = PG_GETARG_INT32(0);int32 b = PG_GETARG_INT32(1);int32 sum = a + b;PG_RETURN_INT32(sum);}
创建.sql文件
.sql
文件中主要是写入创建FUNCTION
和TYPE
的SQL语句。vim
新建一个以插件名+插件版本号命名的.sql
文件(这里demo
是插件名,--1.0
是版本号)。
[root@localhost demo]# vim demo--1.0.sql
.sql
具体内容如下:
CREATE FUNCTION my_sum(INTEGER,INTEGER)
RETURNS INTEGER
AS '$libdir/demo'
LANGUAGE C STRICT;
- 注意:SQL语句中的函数名要和上面
.c
中定义的函数保持一致。 - 其中
$libdir
这个变量是PG安装位置下的静态库文件的默认存储路径,可以用[root@localhost ~]# pg_config --pkglibdir
这一命令查看具体的路径,可以不用管,后面直接接与插件名一致的目录即可,这里接的是demo
。 - 如果
.c
文件中定义了多个函数,.sql
文件中的AS
后面需要指明是demo.c
中的哪一个函数,即:
CREATE FUNCTION …
… …
AS '$libdir/demo', 'my_sum'
… …
二、创建 .control 和 Makefile 文件
创建 .control 文件
- 在PostgreSQL中,后缀为
.control
的文件是一个扩展的控制文件。它用于管理和描述特定扩展的元数据和配置信息。 - 控制文件通常与扩展相关联,并存储了有关扩展的重要信息,例如扩展的名称、版本、所需依赖项等。这些文件还可以包含其他配置选项,以更好地定义和管理扩展的行为。
- 通过使用
.control
文件,PostgreSQL能够根据需要加载和卸载扩展,并确保正确配置和使用扩展。这些文件对于扩展的安装、更新和卸载过程都起着重要作用。 - 总结:
.control
文件是PostgreSQL中扩展的元数据文件,用于管理和配置扩展的属性和行为。
[root@localhost demo]# vim demo.control
.control
文件基本内容如下:
comment = 'test demo'
default_version = '1.0'
module_pathname = '$libdir/demo'
relocatable = true
comment
配置项:用于提供关于扩展的注释或描述性文本。它允许开发人员向用户提供有关扩展功能、用途或其他相关信息的说明。这些注释可以帮助用户更好地理解和使用扩展.relocatable
配置项:用于指定扩展是否可重定位。如果设置为true
,则表示扩展可以在不重新编译数据库的情况下移动到不同的安装位置。这对于在多个数据库实例之间共享和部署扩展非常有用。默认情况下,该配置项的值是false
。- 注意:
default_version
要与最新版本的.sql
文件名中的版本号保持一致。
创建 Makefile 文件
Makefile
文件本质上是shell命令的集合,用于一系列源代码文件的自动化编译,用make指令执行一个Makefile
文件,可以根据文件中的编译规则对一系列源代码文件进行不同的编译。- 这里贴一个Linux下编译链接相关文件的流程说明(根据自己的理解总结的图,有错误敬请指出):
- 回到正题,
Makefile
文件由变量们和编译规则构成:- 定义变量的基本格式是
变量名 = 变量值
,使用变量的基本格式和shell一致$(变量名)
。 - 对某个源码文件的编译规则编写的语法基本格式如下:
- 定义变量的基本格式是
目标文件1:依赖文件1(Tab键)规则1(依赖文件1怎么生成目标文件1的,也就是用依赖文件生成目标文件的方法)目标文件2:依赖文件2(Tab键)规则2(依赖文件2怎么生成目标文件2的)
- 依赖文件对应上图
.c
、.cpp
等源码文件,目标文件对应上图中.o
文件。 - 规则对应编译命令
gcc [编译选项] (编译对象)
- 实例:
demo.o:demo.cgcc -c demo.c
- 更多
Makefile
格式相关的内容见 Makefile-详细说明 和 手把手教你写一个 Makefile 文件。 Makefile
基本内容如下:
MODULES = demoEXTENSION = demo
DATA = demo--1.0.sql
PGFILEDESC = "demo - various functions that return tables" # 描述
OBJS = demo.o # 待生成的目标文件的名字,可以有多个,用空格分开
CC = gcc # 编译器的名称REGRESS = tablefuncLDFLAGES_SL += $(filter -lm, $(LIBS)) # 这一句的作用是如果有多个源码文件编译生成的.o目标文件,把这些.o文件打包成一个静态库文件,什么是打包?为什么要打包?什么是链接?解释均见上图# 下面这一段中主要是一个条件分支语句,分别是用PGXS和不用PGXS进行扩展编译的情况。
# 变量PGXS:如果您正在考虑contribute PostgreSQL扩展模块,那么为它们建立一个可移植的构建系统可能相当困难。
# 因此,PostgreSQL安装为扩展提供了一个称为PGXS的构建基础设施,从而可以简单地针对已经安装的服务器来构建简单的扩展模块。
# PGXS主要用于包含C代码的扩展,尽管它也可以用于纯SQL扩展。
# 请注意,PGXS并不是一个通用的构建系统框架,可以用来构建任何与PostgreSQL接口的软件;它简单地自动化了简单服务器扩展模块的通用构建规则。对于更复杂的包,您可能需要编写自己的构建系统。# 以上是对PGXS的解释,总结来说就是更方便用户自己进行扩展编译的一个模块
# ifdef NO_PGXS,如果不用PGXS进行编译,那么就需要手动设置编译选项、链接库路径等,需要利用Makefile.global文件中指定的pg_config中includefir和libdir指明lib库和include库的位置,如下图
# 走上面这个条件分支编译时有可能会出现缺少一些依赖文件的情况,需要在源码中找到文件复制到demo/目录下来
# else,就是用PGXS编译的情况(可以选择编译时加参数 USE_PGXS=1) ,此时 Makefile 会通过 abase 自带命令 pg_config 来查找 lib 库和 include 库的位置,而命令 pg_config 已默认加载在数据库 owner 的 PATH 环境变量中,可直接使用。# 总之下面这一段通常情况下的扩展可以直接照搬,不用修改# USE_PGXS = 1,如果加了这一句,进入else的条件分支
ifdef NO_PGXS
subdir = contrib/extensions
top_builddir = ../..
include $(top_builddir)/src/Makefile.global
include $(top_srcdir)/contrib/contrib-global.mk
else # = ifdef USE_PGXS
PG_CONFIG = pg_config
PGXS := $(shell $(PG_CONFIG) --pgxs)
include $(PGXS)
endif
PG源码地址/src/Makefile.global
文件截图如下:
三、编译 & 链接
- 在demo目录下执行
make
和make install
[root@localhost demo]# make
gcc -std=gnu99 -Wall -Wmissing-prototypes -Wpointer-arith -Wdeclaration-after-statement -Werror=vla -Wendif-labels -Wmissing-format-attribute -Wformat-security -fno-strict-aliasing -fwrapv -fexcess-precision=standard -g -O0 -fPIC -I. -I./ -I/opt/pgsql-15.3/include/server -I/opt/pgsql-15.3/include/internal -D_GNU_SOURCE -c -o demo.o demo.c -MMD -MP -MF .deps/demo.Po
gcc -std=gnu99 -Wall -Wmissing-prototypes -Wpointer-arith -Wdeclaration-after-statement -Werror=vla -Wendif-labels -Wmissing-format-attribute -Wformat-security -fno-strict-aliasing -fwrapv -fexcess-precision=standard -g -O0 -fPIC demo.o -L/opt/pgsql-15.3/lib -Wl,--as-needed -Wl,-rpath,'/opt/pgsql-15.3/lib',--enable-new-dtags -shared -o demo.so# 编译成功之后会出现 demo.o 和 demo.so 两个文件
[root@localhost demo]# ls
demo.c demo.control demo.o demo.so Makefile[root@localhost demo]# make install
/usr/bin/mkdir -p '/opt/pgsql-15.3/share/extension'
/usr/bin/mkdir -p '/opt/pgsql-15.3/share/extension'
/usr/bin/mkdir -p '/opt/pgsql-15.3/lib'
/usr/bin/install -c -m 644 .//demo.control '/opt/pgsql-15.3/share/extension/'
/usr/bin/install -c -m 644 .//demo--1.0.sql '/opt/pgsql-15.3/share/extension/'
/usr/bin/install -c -m 755 demo.so '/opt/pgsql-15.3/lib/'# 扩展安装成功之后,PG安装目录下的./share/extensions/目录下会出现demo--1.0.sql文件和demo.control文件
[root@localhost demo]# ls /opt/pgsql-15.3/share/extension/
demo--1.0.sql plpgsql.control postgres_fdw.control
demo.control postgres_fdw--1.0--1.1.sql
plpgsql--1.0.sql postgres_fdw--1.0.sql
四、psql(或者其他PG backend)中创建扩展
posgres=# create extension demo;
CREATE EXTENSION
posgres=#
posgres=# select my_sum(1,2);my_sum
--------3
(1 row)
相关文章:

PostgreSQL-UDF用户自定义函数-扩展插件
目录 PostgreSQL-UDF用户自定义函数-扩展插件零、前置条件一、创建 .c 和 .sql 文件创建.c文件创建.sql文件 二、创建 .control 和 Makefile 文件创建 .control 文件创建 Makefile 文件 三、编译 & 链接四、psql(或者其他PG backend)中创建扩展 Post…...

接口测试及接口抓包常用测试工具和方法?
作为测试领域中不可或缺的一环,接口测试和抓包技术在软件开发过程中扮演着至关重要的角色。不论你是新手还是有一些经验的小伙伴,本篇文章都会为你详细介绍接口测试的基本概念、常用测试工具和实际操作技巧,让你轻松掌握这一技能。 接口测试…...

C语言入门_Day 6布尔数与比较运算
目录 前言 1.布尔数 2.比较运算 3.易错点 4.思维导图 前言 除了算术计算以外,编程语言中还会大量使用比较运算,并会根据比较运算的结果是“真”还是“假”,来执行不同的代码。 当你想买一杯奶茶,准备支付的时候,支…...

Java中的JDBC
什么是JDBC 1.Java数据库连接技术(Java DataBase Connectivity),能实现Java程序对各种数据库的访问 2.由一组使用Java语言编写的类和接口(JDBC API)组成,它们位于java.sql以及javax.sql中 JDBC访问数据库的步骤: 步骤 1.Class.forName()加载…...

Vue 安装开发者工具
1.下载开发者工具,下载地址:http://book.wiyp.top/App/Vue3开发者工具-谷歌/Vue3.crx 2.打开谷歌浏览器,点击扩展,点击管理扩展程序。 3.开启开发者模式,将 Vue3 开发者工具文件拖拽到浏览器中进行安装。 注ÿ…...
oracle修改临时表出现已使用的事务正在处理临时表问题
错误提示: ORA-14450:试图访问已经在使用的事务处理临时表 解决方法: 通过第一句sql来查找临时表的object_id ,然后代入第二局sql来生成第三句sql语句。 最后再执行第三句sql语句即可kill session,执行修改表的操作。 SELECT * F…...

RestTemplate
RestTemplate介绍 RestTemplate是Spring提供的用于访问RESTful服务的客户端,RestTemplate提供了多种便捷访问远程Http服务的方法,能够大大提高客户端的编写效率。RestTemplate默认依赖JDK提供http连接的能力(HttpURLConnection),…...

rabbitMQ服务自动停止(已解决
1、 在rabbitmq的sbin目录下操作 rabbitmq-plugins enable rabbitmq_management 2、 自己去rabbitmq_server-3.7.5文件夹下创建一个data,再执行这个命令(用自己的目录哈 set RABBITMQ_BASED:\RabbitTools\RabbitMQ\rabbitmq_server-3.7.5\data 然后去配…...

Qt平滑弹出页面
目标功能: (1)按下btn,弹出绿色页面。 (2)按下btn2,绿色页面隐藏。 (3)按下左边余下的区域,绿色页面也隐藏。 (4)平滑地显示和隐藏 效果: form.h #ifndef FORM_H #define FORM_H#include <QWidget>namespace Ui { class…...

第07天 Static关键字作用及用法
✅作者简介:大家好,我是Leo,热爱Java后端开发者,一个想要与大家共同进步的男人😉😉 🍎个人主页:Leo的博客 💞当前专栏:每天一个知识点 ✨特色专栏:…...
Redis扩容与一致性Hash算法解析
推荐阅读 AI文本 OCR识别最佳实践 AI Gamma一键生成PPT工具直达链接 玩转cloud Studio 在线编码神器 玩转 GPU AI绘画、AI讲话、翻译,GPU点亮AI想象空间 资源分享 「java、python面试题」来自UC网盘app分享,打开手机app,额外获得1T空间 https://dr…...

【第七讲---视觉里程计1】
视觉里程计就是通过对图像进行特征提取与匹配得到两帧之间的位姿,并进行估计相机运动。 经典SLAM中以相机位姿-路标来描述SLAM过程 特征提取与匹配 路标是三维空间中固定不变的点,可以在特定位姿下观测到在视觉SLAM中,可利用图像特征点作为…...
Linux: sched: might_sleep; 一个调试函数,演变为真实的睡眠函数,实至名归
#define might_sleep() do { might_resched(); } while (0) #ifdef CONFIG_PREEMPT_VOLUNTARY extern int _cond_resched(void); # define might_resched() _cond_resched(...

(三) 搞定SOME/IP通信之CommonAPI库
本章主要介绍在SOME/IP通信过程中的另外一个IPC通信利剑,CommonAPI库,文章将从如下几个角度让读者了解什么是CommonAPI, 以及库在实际工作中的作用 文中资源:vsomeipcommonapi指导文档与demo源码 SOME/IP通信之CommonAPI CommonAPI库是什么C…...
windows bat脚本,使用命令行增加/删除防火墙:入站-出站,规则
常常手动设置防火墙的入站或出站规则,比较麻烦,其实可以用命令行搞定。 下面是禁用BCompare.exe连接网络的例子: ECHO OFF&(PUSHD "%~DP0")&(REG QUERY "HKU\S-1-5-19">NUL 2>&1)||(powershell -Comm…...

Stable Diffusion 告别复制关键词,高质量提示词自动生成插件
在使用SD时,我们经常会遇到心中无想法,或不知如何描述心中所想的图像。有时由于提示词的选择不当,生成的图片质量也不尽如人意。为此,我今天为大家推荐一个高质量的提示词自动生成插件——One Button Prompt。 下面是他生成的一些样图。 文章目录 插件安装插件说明主菜单工…...

【学习日记】【FreeRTOS】任务调度时如何考虑任务优先级——任务的自动切换
写在前面 本文开始为 RTOS 加入考虑任务优先级的自动调度算法,代码大部分参考野火。 本文主要是一篇学习笔记,加入了笔者自己对野火代码的梳理和理解。 一、基本思路 首先我们要知道,在 RTOS 中,优先级越高、越需要被先执行的的…...

C语言暑假刷题冲刺篇——day3
目录 一、选择题 二、编程题 🎈个人主页:库库的里昂 🎐CSDN新晋作者 🎉欢迎 👍点赞✍评论⭐收藏✨收录专栏:C语言每日一练✨其他专栏:代码小游戏C语言初阶🤝希望作者的文章能对你有…...
Taro+vue3小程序开启分享他人和分享到朋友圈
import Taro, { useShareAppMessage, useShareTimeline } from tarojs/taro;onMounted(() > {Taro.showShareMenu({withShareTicket: true,menus: [shareAppMessage, shareTimeline]}); }); useShareAppMessage((res) > {console.log(页面转发的回调)return {title: 开票…...

JAVA-Spring中IOC容器是什么?
目录 JAVA-Spring中IOC容器是什么?什么是IOC?什么是IOC容器?IOC和IOC容器的对比Spring框架中的IOC容器是如何工作的?使用XML配置的ApplicationContext使用注解的AnnotationConfigApplicationContext总结 JAVA-Spring中IOC容器是什…...

idea大量爆红问题解决
问题描述 在学习和工作中,idea是程序员不可缺少的一个工具,但是突然在有些时候就会出现大量爆红的问题,发现无法跳转,无论是关机重启或者是替换root都无法解决 就是如上所展示的问题,但是程序依然可以启动。 问题解决…...
模型参数、模型存储精度、参数与显存
模型参数量衡量单位 M:百万(Million) B:十亿(Billion) 1 B 1000 M 1B 1000M 1B1000M 参数存储精度 模型参数是固定的,但是一个参数所表示多少字节不一定,需要看这个参数以什么…...

云启出海,智联未来|阿里云网络「企业出海」系列客户沙龙上海站圆满落地
借阿里云中企出海大会的东风,以**「云启出海,智联未来|打造安全可靠的出海云网络引擎」为主题的阿里云企业出海客户沙龙云网络&安全专场于5.28日下午在上海顺利举办,现场吸引了来自携程、小红书、米哈游、哔哩哔哩、波克城市、…...
在rocky linux 9.5上在线安装 docker
前面是指南,后面是日志 sudo dnf config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo sudo dnf install docker-ce docker-ce-cli containerd.io -y docker version sudo systemctl start docker sudo systemctl status docker …...
可靠性+灵活性:电力载波技术在楼宇自控中的核心价值
可靠性灵活性:电力载波技术在楼宇自控中的核心价值 在智能楼宇的自动化控制中,电力载波技术(PLC)凭借其独特的优势,正成为构建高效、稳定、灵活系统的核心解决方案。它利用现有电力线路传输数据,无需额外布…...
基于Java Swing的电子通讯录设计与实现:附系统托盘功能代码详解
JAVASQL电子通讯录带系统托盘 一、系统概述 本电子通讯录系统采用Java Swing开发桌面应用,结合SQLite数据库实现联系人管理功能,并集成系统托盘功能提升用户体验。系统支持联系人的增删改查、分组管理、搜索过滤等功能,同时可以最小化到系统…...

【Redis】笔记|第8节|大厂高并发缓存架构实战与优化
缓存架构 代码结构 代码详情 功能点: 多级缓存,先查本地缓存,再查Redis,最后才查数据库热点数据重建逻辑使用分布式锁,二次查询更新缓存采用读写锁提升性能采用Redis的发布订阅机制通知所有实例更新本地缓存适用读多…...

C++ 设计模式 《小明的奶茶加料风波》
👨🎓 模式名称:装饰器模式(Decorator Pattern) 👦 小明最近上线了校园奶茶配送功能,业务火爆,大家都在加料: 有的同学要加波霸 🟤,有的要加椰果…...
【Ftrace 专栏】Ftrace 参考博文
ftrace、perf、bcc、bpftrace、ply、simple_perf的使用Ftrace 基本用法Linux 利用 ftrace 分析内核调用如何利用ftrace精确跟踪特定进程调度信息使用 ftrace 进行追踪延迟Linux-培训笔记-ftracehttps://www.kernel.org/doc/html/v4.18/trace/events.htmlhttps://blog.csdn.net/…...
13.10 LangGraph多轮对话系统实战:Ollama私有部署+情感识别优化全解析
LangGraph多轮对话系统实战:Ollama私有部署+情感识别优化全解析 LanguageMentor 对话式训练系统架构与实现 关键词:多轮对话系统设计、场景化提示工程、情感识别优化、LangGraph 状态管理、Ollama 私有化部署 1. 对话训练系统技术架构 采用四层架构实现高扩展性的对话训练…...