Как отправить команду SQL внутри функции языка C в расширении PostgreSQL (Apache AGE)?

Я работаю над расширением PostgreSQL (Apache AGE), и мне нужно выполнить команду SQL из функции языка C. Как я могу этого добиться?

Для контекста я разрабатываю расширение, которое изменяет некоторые таблицы в базе данных, и мне нужно запустить несколько команд ALTER TABLE, чтобы добавить или удалить столбцы, переименовать столбцы или изменить типы столбцов, в зависимости от определенных условий. У меня уже есть функция C, которая выполняет необходимые вычисления, но я не знаю, как выполнить SQL-команду из нее.

Вот упрощенная версия моего кода:

PG_FUNCTION_INFO_V1(my_function);

Datum
my_function(PG_FUNCTION_ARGS)
{
    // Perform some computations...

    // Execute a SQL command (not sure how to do this)...

    PG_RETURN_NULL();
}

Может ли кто-нибудь показать мне, как выполнить команду SQL внутри функции C в расширении PostgreSQL? Любая помощь будет оценена по достоинству!

Стоит ли изучать PHP в 2023-2024 годах?
Стоит ли изучать PHP в 2023-2024 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
1
0
100
4
Перейти к ответу Данный вопрос помечен как решенный

Ответы 4

Для этого вы можете использовать SPI (интерфейс серверного программирования).

Интерфейс серверного программирования (SPI) предоставляет авторам определяемые пользователем C функции возможность запускать SQL-команды внутри своих функций или процедуры. SPI — это набор интерфейсных функций для упрощения доступа к парсер, планировщик и исполнитель. SPI также выполняет некоторую память управление.

Пример: https://www.postgresql.org/docs/current/spi-examples.html

Ответ принят как подходящий

Вы можете использовать SPI (серверный программный интерфейс), предоставляемый postgreSQL для разработчиков расширений.

Это набор функций и макросов языка C, которые позволяют выполнять команды и запросы SQL на сервере PostgreSQL.

Используя интерфейс SPI, код C может:

  • Подготовка и выполнение операторов SQL
  • Получение и обработка результатов запроса
  • Доступ к таблицам и индексам
  • Обработка ошибок и исключений

В этом контексте ваша функция ALTER TABLE может выглядеть так:

#include "postgres.h"
#include "fmgr.h"
#include "utils/elog.h"
#include "commands/trigger.h"
#include "access/xact.h"
#include "executor/spi.h"

PG_MODULE_MAGIC;

PG_FUNCTION_INFO_V1(alter_table_func);

Datum alter_table_func(PG_FUNCTION_ARGS)
{
    int ret;
    char *sql = "ALTER TABLE my_table ADD COLUMN new_column INTEGER";

    SPI_connect();
    ret = SPI_execute(sql, true, 0);
    SPI_finish();

    if (ret != SPI_OK_UTILITY)
        elog(ERROR, "ALTER TABLE failed");
    PG_RETURN_VOID();
}

Вы можете узнать больше здесь: СПИ | Примеры SPI

Вы можете запускать операторы sql внутри кода функции C с помощью интерфейса программирования сервера (SPI). Я предлагаю вам прочитать больше об этом здесь, чтобы увидеть, что именно вам нужно, чтобы ваш код работал.

Вы можете достичь этого. Один из способов - использовать интерфейс программирования сервера, предоставляемый postgreSQL.

Интерфейс серверного программирования позволяет использовать определяемые пользователем функции C для запуска команд SQL внутри их функций или процедур. Источник: Официальный документ Postgres

сначала вы должны включить необходимые заголовки #include "исполнитель/spi.h" затем внутри вызова функции SPI_connect()

Другие вопросы по теме