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

Всем привет, такой вопрос, можно ли управлять транзакциями в самих

хранимках и функциях?

22 ответов

13 просмотров

Лучшэ найти другой способ решэния своих проблем.

Geffest- Автор вопроса

На самом деле, несколько лет назад дали возможность управлять транзакцыями в процэдурах. Иногда. Там много ограничений (например, по пути вызова не должно быть ни одной функцыи, и это должэн быть чисто вызов процэдуры через call), оно сделано в странном для этого месте. В большынстве случаев попытка этим воспользоваться означает, что вы неправильно взяли инструмент для задачи.

Geffest
По типу оборачивания при вызове?

Не очень понимаю, что вы имеете в виду. Но чаще всего, если начинает речь идти о нескольких транзакцыях — то лучшэ подобную логику писать на ЯП общего назначения, вне базы. Это и удобнее и разгружает сервер БД.

Geffest
По типу оборачивания при вызове?

С другой стороны, второй вариант, зачем люди хотят транзакцыи внутри процэдур — частичный commit, частичный откат. Типа как savepoint/subtransactions. Всё это делается через begin ... except. Внутри реализацыи в pl/pgSQL — те жэ savepoints.

Ilya Anfimov
На самом деле, несколько лет назад дали возможност...

Ну вот это меня удивляет всегда. Я то очень за полное управление транзакциями в процедурах. Но я почему-то никогда не думал даже чтобы запрещать это делать в других местах или иным образом. Почему такая дискриминация ?

Geffest
По типу оборачивания при вызове?

Третий вариант, зачем люди хотят транзакцыи — коммитить логи какие-то, независимо от результатов. Но управление транзакцыями как таковое тут не очень поможэт — там всё могут быть откаты, но скорее помешает. Тут я посоветую вещи вроде fdw/dblink и использования спецыальных коллекторов логов.

Ilya Zviagin
Ну вот это меня удивляет всегда. Я то очень за по...

Пытаться управлять транзакциями на разных уровнях вложенности вызовов это неотлаживаемый и неподдерживаемый кошмар.

Роман Жарков
Пытаться управлять транзакциями на разных уровнях ...

Ну, это зависит от того, как ты это будешь делать. Я может и буду делать как раз реальное управление транзакциями только на первом уровне вызова.

Ilya Zviagin
Ну вот это меня удивляет всегда. Я то очень за по...

А почему Вы "за"? Практически почти бесполезная возможность, IMNSHO. > Почему такая дискриминация ? Потому что так предписывает ISO SQL, а мы тут на него молимся. ;)

Ilya Zviagin
Ну, это зависит от того, как ты это будешь делать....

Маааленький нюанс: не «ты», а «вы». Хотя бы человек десять.

Yaroslav Schekin
А почему Вы "за"? Практически почти бесполезная во...

О! Вот и секта свидетелей Святого ISO SQL образовалась!

Роман Жарков
Маааленький нюанс: не «ты», а «вы». Хотя бы челове...

Ну, у меня 20 было, и что.. Ладно, бессмысленный спор

Ilya Zviagin
Ну, у меня 20 было, и что.. Ладно, бессмысленный...

И все транзакции лепили где вздумается? В общих библиотечных функциях?

Роман Жарков
И все транзакции лепили где вздумается? В общих би...

Чё вам дались эти функции, я не понимаю... Нет, не лепили где вздумается. Лепили, где положено.

Ilya Zviagin
Чё вам дались эти функции, я не понимаю... Нет, не...

Тогда рекомендую pgpro atx. Там этих транзакций можно штук сто в глубину налепить.

Ilya Anfimov
О! Вот и секта свидетелей Святого ISO SQL образова...

Что касается именно разработчиков СУБД PostgreSQL — Вы уже давно в ней (пользуетесь результатами их труда, по крайней мере). ;)

Yaroslav Schekin
Что касается именно разработчиков СУБД PostgreSQL ...

Это чтож, мы тут незаконной миссионерской деятельностью занимаемся, получается? Ой гевалт!

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

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

Типа вызывать GetParent и проверять на соответствие GetModuleHandle?
The Bird of Hermes
67
Всем привет! Кто нибудь парсил в ручную JSON без библиотек и фреймворков? Есть может ссылки на оптимальный алгоритмы работы с текстом и примеры таких парсеров?
Lem
27
Do any of you guys have interesting projects one could join? I'm a Middle Full-Stack developer (JS/TS, React & Node)
Lev Shapiro
40
Есть сайт. Там была древняя версия эво. Стоял плагин, который каждый коммент в Jot делал отдельной страницей. После обновления все слетело, теперь старница открывается отдельн...
Artem
1
$res = json_decode($наша строка из респонса); $res1 = array_map(fn($o) => $o->name, $res->breadcrumbs[0]->entities); Как такое будет на Хаскеле?.. В начале весь джейсон, в ко...
Хаскель Моисеевич Гопник
27
Добрый день. А shovel'ы можно как-то сконфигурировать в definitions.json? Пробовал что-то вроде: { "users": [ { "name": "agent", "password_hash": "RBCbTzQd...
Aleksey
1
Вопрос по диагностике ошибок (я знаю в чем, в данном конкретном примере, я знаю, как исправить, пример модельный, понятно, что в реальности бывает намного запутаннее). module...
ⰄⰎⰋⰐⰐⰑⰛⰤⰧⰧⰩⰄ ⰊⰑⰁⰓⰡⰛⰦⰕⰫ
11
А чем вам питонисты не угодили?😂
.
79
В чем сила брат, в NASM или FASM?
Isaac Kleiner
18
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
52
Карта сайта