|
43 / 43 / 20
Регистрация: 08.12.2010
Сообщений: 342
|
|||||||||||
PostgreSQL склад28.10.2016, 14:45. Показов 3064. Ответов 2
Метки нет (Все метки)
Учитывая рекомендации, перестроил базу данных (Вот небольшая часть, необходимая для интересующего меня вопроса):
Собственно сейчас задумано следующее, на складе, есть какие то продукты, необходимо сформировать запись расхода. В отдельном интерфейсе выбирается количество и товары. Далее внутри самой программы (ПО на GOLANG), считываются цены, из отдельного микросервиса, по всем продуктам и сумма заносятся в поле "Total". После чего с помощью таблицы калькуляции вычисляется сколько продуктов после обработки должно получиться на точке. После того как я вытащил цену, мне необходимо, произвести своего рода транзакцию, т.е. вычесть определенное количество продуктов со указанного склада ( Имя склада есть в функции обработчике в программе ). Вопрос: Как будет правильно это осуществить? 1 вариант: В программе создать собственную эмуляцию транзакции, которая в случае чего вернет все на место. (Но по моему это будет просто дико нагружать сервер) 2 вариант: Сделать триггер с изменяемым названием склада (Пока даже не представляю, как это сделать) 3 вариант: Хранимая процедура, так же с изменяемым названием склада. (Коммент от второго) 2-3 варианты не рекомендую в интернете, так как оно вечно будет что то пересчитывать и постоянно через prepare. Если приведете примеры для динамического имени склада для моего примера, буду благодарен. Спасибо за внимание =) Добавлено через 21 минуту Можно сделать более лаконично? А то к примеру в update через RETURNING у меня не работало =(
0
|
|||||||||||
| 28.10.2016, 14:45 | |
|
Ответы с готовыми решениями:
2
PostgreSQL 9.4.10 1с PostgreSQL мониторинг postgresql |
|
1264 / 978 / 384
Регистрация: 02.09.2012
Сообщений: 3,021
|
||
| 29.10.2016, 01:51 | ||
|
Я вот читаю код (триггера) и не понимаю, что нельзя одним UPDATE'ом обойтись. "UPDATE .... SET ... WHERE Name=(SELECT ....) AND .... RETURNING ..." Вообще каждое выражение postgresql выполняет как бы в транзакции (хоть вы ее явно и не определяете). Конечно, это еще может зависеть от клиента, через которого вы передаете sql-команды.
1
|
||
|
43 / 43 / 20
Регистрация: 08.12.2010
Сообщений: 342
|
|||||||
| 29.10.2016, 09:15 [ТС] | |||||||
Вот в таком виде функция не запихивала в allcount необходимое значение, хотя если просто в консоли pgadmin использовать данный запрос, то все хорошо. Собственно поэтому была реализована дополнительная функция. А что касается внутреннего select, что то не подумал спасибо.
0
|
|||||||
| 29.10.2016, 09:15 | |
|
Помогаю со студенческими работами здесь
3
PostgreSQL + MCBC Обновление Postgresql 9.1 - 9.6 PostgreSQL функции
GUID postgresql 9.3 Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так:
https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347
Основана на STM32F303RBT6.
На борту пять. . .
|
Символьное дифференцирование
igorrr37 13.02.2026
/ *
Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет
значение производной при заданном х
Логарифм записывается как: (x-2)log(x^2+2) -. . .
|
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
|
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу,
и светлой Луне.
В мире
покоя нет
и люди
не могут жить в тишине.
А жить им немного лет.
|
|
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила»
«Время-Деньги»
«Деньги -Пуля»
|
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога
Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
|
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога
Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
|
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога
Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
|