sql >> Database >  >> RDS >> PostgreSQL

Een extensietest maken in postgresql

Dit is een minimaal voorbeeld dat werkt als je de postgresql-server . hebt ontwikkelpakket voor ubuntu geïnstalleerd

extensie.c
Een simpele uitbreiding

/* Postgres headers */
#include <postgres.h>
#include <utils/rel.h>

#include <stdio.h>
#include <string.h>

#ifdef PG_MODULE_MAGIC
PG_MODULE_MAGIC;
#endif

static char *
extract_string(text *word)
{
    char *head;
    char *tail;

    if (word == NULL)
        return NULL;

    head = VARDATA(word);
    tail = head + VARSIZE(word) - VARHDRSZ;
    tail[0] = '\0';

    return head;
}

PG_FUNCTION_INFO_V1(compare_strings);
Datum
compare_strings(PG_FUNCTION_ARGS)
{
    char *lhs;
    char *rhs;

    lhs = extract_string(PG_GETARG_TEXT_P(0));
    rhs = extract_string(PG_GETARG_TEXT_P(1));

    PG_RETURN_BOOL(strcmp(lhs, rhs) == 0);
}

Makefile
Een eenvoudige Makefile om te illustreren hoe je de extensie zou kunnen bouwen.

CC     = gcc
OBJECT = extension.o
NAME   = my-extension.so
CFLAGS = -Wall -Werror -g3 -O0 -I$(shell pg_config --includedir-server)

all: $(OBJECT)
    $(CC) -shared -o $(NAME) $(OBJECT)

%.o: %.c
    $(CC) -c -fPIC $(CFLAGS) $<

install: all
    @install -Dv -m755 $(NAME) $(shell pg_config --pkglibdir)/$(NAME)
    @psql -U postgres -f create-function.sql

clean:
    @rm -fv *.o *.so

create-function.sql
Een eenvoudig script om de functie te maken

CREATE OR REPLACE FUNCTION 
    compare_strings(VARCHAR,VARCHAR) RETURNS integer AS 'my-extension' 
LANGUAGE C STRICT;

Zoals uit uw vraag blijkt, zult u begrijpen wat dit doet en ook hoe u het kunt laten werken voor uw gebruik.



  1. Hoe gebruik ik speciale tekens in MySQL-kolomnamen?

  2. Waarom slaat mysql sommige auto-increment-id's over?

  3. Hoe kan ik aangrenzende rijen selecteren op een willekeurige rij (in sql of postgresql)?

  4. Hoe moet ik een GUID opslaan in Oracle?