向pg内核中添加函数主要分为两种
1.在已有的.c文件中加入自己的函数
2.自己创建一个.c文件
在第一种情况下举一个简单的例子:
首先,在某个已有的.c文件下添加自己函数体,如在src\backend\utils\adt\pseudotypes.c下,添加:
Datum
my_func(PG_FUNCTION_ARGS)
{
char *str = pstrdup("Hello ,Postgres World!");
PG_RETURN_TEXT_P(cstring_to_text(str));
}
函数体已经添加,接下来是最关键的一步。打开src\include\catalog\pg_proc.h
在里面添加两行代码(任意位置均可,具体参数信息会在文章底部说明)
DATA(insert OID = 9999 (helloworld PGNSP PGUID 12 1 0 0 0 f f f f t f i 0 0 25 "" _null_ _null_ _null_ _null_ _null_ my_func _null_ _null_ _null_));
DESCR("helloworld");
要注意的有
(1)格式要正确
(2)需要使用一个未被使用过的oid(这个可以使用src\include\catalog目录下的unused_oids进行查看,如果无法使用要先使用命令 sudo chmod +x * 对当前文件添加运行权限。)
添加完上面的两行代码后需要重新configure、make、make install安装数据库,再使用命令initdb初始化后启动数据库。
启动数据库后就可以调用该函数了,如下
以上就是一个最简单的helloworld的函数的实现,下面我们开始自己创建一个.c文件
第二种情况:
第一步:
我们先创建一个.c文件,我们在src/backend/utils/adt目录下新建一个page_mgr.c文件,并加入如下代码:
/*-------------------------------------------------------------------------
* page_mgr.c
* Functions for direct access to page
*----------------------------------