Параллельное выполнение функций в Postgres

У меня есть дорогостоящая функция, которую я использую в запросе, который я хотел бы выполнять параллельно, но postgres, похоже, не хочет этого делать.

В основном просто делаю:

SELECT expensive_func(a, b, c) FROM table;

Разве нельзя добиться этого, чтобы использовать параллельное последовательное сканирование? Или есть какая-то конфигурация, мешающая мне это сделать?

Функция помечена как параллельная безопасная, и максимальное количество параллельных рабочих на сборку установлено соответствующим образом.

Это Postgres 9.6.3

Объявление функции:

  CREATE OR REPLACE FUNCTION expensive_func(args...)
    RETURNS result
    LANGUAGE plpgsql
    STABLE
    PARALLEL SAFE
    AS $$

У вас есть параллельное сканирование с SELECT * FROM "table"? Вы можете показать заявление CREATE FUNCTION (точное тело не важно)?

Laurenz Albe 12.05.2018 06:25
show dynamic_shared_memory_type? ..
Vao Tsun 14.05.2018 13:55

@LaurenzAlbe только что добавил объявление функции. Я не получаю параллельное сканирование только с выбором. Я читал, что для параллельного сканирования требуется предложение where. Я получаю параллельное сканирование с операторами select, в которых есть предложения where. Но разве нет способа указать postgres использовать параллельное сканирование для распараллеливания дорогостоящей функции без предложения where?

dan 15.05.2018 00:49

@VaoTsun dynamic_shared_memory_type - это posix

dan 15.05.2018 00:50

Если сканируется вся таблица, стоимость каждой строки составляет parallel_tuple_cost (по умолчанию 0,1). Выбран параллельный план, если вы уменьшите это значение? Что делать, если у вас SET force_parallel_mode=on? Фактическая продолжительность меньше при параллельном плане?

Laurenz Albe 15.05.2018 05:52
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать 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
5
1 042
0

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