172 похожих чатов

Добрый вечер. Видимо я переутомился. Изменения таблиц производимые в рамках

открытой транзакции должны быть видны в этой транзакции. Это вроде логично, но возможны ситуации при которых это не так? Поясню ситуацию у меня функция вызываемая в теле функции добавляет запись в таблицу, но когда я пытаюсь ее получить обратно вижу NULL, однако после завершения транзакции(общей вызывающей функции я вижу запись) по моему так не должно быть?

6 ответов

9 просмотров

Не должно. Но если у вас какой-нибудь пулер неправильно настроенный в середине — то можэт.

Вместо тысячи слов нужен пример кода.

Функции не immutable/stable случайно? Попробуйте поменять на volatile https://www.postgresql.org/docs/current/xfunc-volatility.html

Kirill P
Функции не immutable/stable случайно? Попробуйте п...

У функций stable не крутится снапшот, поэтому они могут возвращать одно и то же STABLE and IMMUTABLE functions use a snapshot established as of the start of the calling query, whereas VOLATILE functions obtain a fresh snapshot at the start of each query they execute.

Дмитрий-Иванов Автор вопроса
Kirill P
Функции не immutable/stable случайно? Попробуйте п...

Функция вносит изменения в таблицы, так что изначально проектировалась как volatile. Я обошел проблему получив необходимые данные на основе записей присутствующих в таблице, но вопрос для мене остался открытым. Я не первый раз делаю вложенный вызов функции но первый раз сталкиваюсь с ситуацией когда не могу получить из таблицы произведенные ей изменения которые там совершенно точно есть. Спасибо за советы буду сам ковырять.

Дмитрий-Иванов Автор вопроса
Kirill P
Функции не immutable/stable случайно? Попробуйте п...

Нехороший копипаст... Да я лепил эту функцию из селектовой STABLE и действительно не поменял на VOLATILE, вот жеж... 🤯🖖

Похожие вопросы

Обсуждают сегодня

@MrMiscipitlick А можешь макрос написать, который будет вычислять смещение относительно переданных меток? Просто .label1-.label2, и вернуть значение.
КТ315
35
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
А еще в перле можно уже @arr1 + @arr2?
Sergei Zhmylove
53
Заметил в ghci 9.4.8: > :t (<*>) @((->)_) (<*>) @((->)_) :: (w -> (a -> b)) -> (w -> a) -> w -> b Разве не должно (w -> (a -> b)) быть записано как (w -> a -> b)? Это баг, ил...
Михаил
13
Привет всем. появился вопрос. Разрабатываю сайт, в данный момент он запущен. Хостинг beget. Добавляю на сайт яндекс метрику с помощью полей client-settings (взято отсюда http...
Andrew
2
Подобного рода ;Следующие три строки это директивы ассемблера, ;которые можно не задавать, т.к.работаем в Visual Studio. ;Символ ";" - это начало однострочного комментария ...
Егор Анелькин
3
Any electron dev here?
Sayanth Tezro
12
Подскажите, где смотреть результат выполнения программы? Код: ;.686 ;Система команд процессора 686 ;.MODEL FLAT,stdcall ;Модель памяти плоская, станда...
Егор Анелькин
5
;.686 ;Система команд процессора 686 ;.MODEL FLAT,stdcall ;Модель памяти плоская, стандартный ;вызов процедуры ;option casemap:no...
Егор Анелькин
1
так это может кто что знает или использует что-то как макбук только не макбук? на 13…14 дюймов
Michael
9
Карта сайта