sql >> Database teknologi >  >> RDS >> PostgreSQL

Oprettelse af en udvidelsestest i postgresql

Dette er et minimalt eksempel, der virker, hvis du har postgresql-server udviklingspakke til ubuntu installeret

extension.c
En simpel udvidelse

/* 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
En simpel Makefile til at illustrere, hvordan du kan bygge udvidelsen.

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
Et simpelt script til at oprette funktionen

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

Som det ser ud fra dit spørgsmål, vil du være i stand til at forstå, hvad dette gør, og også hvordan du får det til at fungere i dit tilfælde.



  1. Hvordan bruger jeg LINQ korrekt med MySQL?

  2. karakter 0xc286 af kodning UTF-8 har ingen ækvivalent i WIN1252....Ved konvertering med iconv postgres gendannelsesnedbrud

  3. PHP Cookie for at holde brugeren logget ind - er dette sikkert nok?

  4. Hvordan skriver man en MYSQL CASE WHEN-sætning med flere søgebetingelser?