0 / 0 / 0
Регистрация: 12.11.2016
Сообщений: 10
|
||||||
Триггер plpgsql19.01.2023, 09:17. Показов 433. Ответов 1
Добрый день, подскажите пожалуйста, необходимо автоматически генерировать запись в колонку id_doc следующим форматом:
Р XXXXXX XXX , где 2-7 символы - число, месяц, год текущей даты 8-10 - порядковый номер на текущую дату (т.е. 001, 002 и т.д.) При этом каждый день соответственно из-за смены даты, у нас запись должна меняться, как это можно реализовать? Весь вывод добавил, осталось только это реализовать (синим выделил какой кусок кода надо изменить):
0
|
19.01.2023, 09:17 | |
Ответы с готовыми решениями:
1
Запрос по plpgsql с курсором Plpgsql как пользоваться commit внутри функции plpgsql |
55 / 50 / 5
Регистрация: 30.06.2022
Сообщений: 251
|
|||||||||||||||||||||
19.01.2023, 16:54 | |||||||||||||||||||||
Не надо придавать идентификаторам записи таблиц дополнительные функции! Они не для этого применяются.
Пользуйтесь либо последовательностями и целыми числами, либо UUID и генераторами уникальных значений. В таблицу добавьте поле строку num_doc и пишите туда что угодно. Добавлено через 7 минут Ещё вам нужно поле типа timestamp со значением по умолчанию now() и NOT NULL по этому полю создаётся индекс. Далее пишете функцию простановки поля num_doc для записи, в ней блокируете все строки за день, который берётся из текущей записи, затем запросом вычисляете ваш порядковый номер на текущую дату Далее формируете строку, записываете в поле num_doc и возвращаете управление. Минимум блокировок и реализуется то, что вам нужно. Добавлено через 13 минут
Обратите внимание на нюансы 1)было бы неплохо в код добавить проверки на корректность и чтоб при изменении даты-времени записи не было одинаковых значений в таблице, может, вообще стоит уникальный ключ на это поле добавить в табличку и date_doc сделать NOT NULL. Иначе корректность работы не будет гарантирована. 2) Если реализовать п.1, то не будет сюрпризов при параллельной работе, и при этом блокируется не вся таблица и тормозов скорее всего будет меньше, чем если реализовывать вашим методом. Сорри, если не очень понятно пишу. Добавлено через 7 минут 3)Эту функцию наверное стоит вызывать в триггере после добавления и обновления(но триггер должен срабатывать только, если меняется поле date_doc), тогда он не будет вызываться при каждом обновлении записей
1
|
19.01.2023, 16:54 | ||||||
Помогаю со студенческими работами здесь
2
Plpgsql . вставка данных из файла Триггер для добавления к строке название таблицы, в которой содержится триггер
Триггер, вызывающий процедуру, в которой выполняется select к этой таблице (откуда был вызван триггер) Искать еще темы с ответами Или воспользуйтесь поиском по форуму:
|
|
Новые блоги и статьи
![]() |
||||
Оптимизация производительности Node.js с помощью кластеризации
run.dev 04.04.2025
Масштабирование приложений для обработки тысяч и миллионов запросов — обыденная задача для многих команд. Node. js, благодаря своей асинхронной событийно-ориентированной архитектуре, стал популярной. . .
|
Управление зависимостями в Python с Poetry
py-thonny 04.04.2025
Стандартный инструмент для установки пакетов в Python - pip - прекрасно справляется с базовыми сценариями: установил пакет командой pip install и используешь его. Но что произойдёт, когда разные. . .
|
Мониторинг с Prometheus в PHP
Jason-Webb 04.04.2025
Prometheus выделяется среди других систем мониторинга своим подходом к сбору и хранению метрик. В отличие от New Relic, который использует агентный подход и отправляет данные во внешнее хранилище,. . .
|
Пакет Context в Golang: Управление потоками и ресурсами
golander 04.04.2025
Работа с горутинами в Go часто напоминает управление непослушными детьми - они разбегаются кто куда, делают что хотят и не всегда завершаются вовремя. К счастью, в Go 1. 7 появился пакет context,. . .
|
Контейнеризация React приложений с Docker
Reangularity 03.04.2025
Контейнеризация позволяет упаковать приложение со всеми его зависимостями в автономный контейнер, который можно запустить на любой платформе с установленным Docker. Это существенно упрощает процессы. . .
|
Свой попап в SwiftUI
mobDevWorks 03.04.2025
SwiftUI, как декларативный фреймворк от Apple, предоставляет множество инструментов для создания пользовательских интерфейсов. В нашем распоряжении есть такие API как alerts, popovers, action sheets. . .
|
Антипаттерны микросервисной архитектуры
ArchitectMsa 03.04.2025
Хорошо спроектированная микросервисная система может выдержать испытание временем, оставаясь гибкой, масштабируемой и устойчивой к большинству проблем. Такая архитектура обладает высоким уровнем. . .
|
std::mutex в C++: Советы и примеры использования
bytestream 03.04.2025
std::mutex - это механизм взаимного исключения, который гарантирует, что критический участок кода выполняется только одним потоком в каждый момент времени. Это простое, но могущественное средство. . .
|
Не удержался от оценки концепции двигателя Стирлинга.
Hrethgir 03.04.2025
Сколько не пытался - она выдавала правильные схемы, причём случайно рисовала горячие области в середине, холодные по краям, трубки с краёв в низ и магнит в соединяющей, но при этой выдавала описание. . .
|
Метод с двумя буферами (или double buffering) или ping-pong buffering
Hrethgir 02.04.2025
Из ответов LM модели.
Метод, который предполагает использование двух массивов для хранения промежуточных результатов сложения векторов, обычно применяется в сценариях, где необходимо минимизировать. . .
|