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

Pl/Pgsql в рамках триггера на изменение данных нужно взять всё

что есть в NEW
и втсавить в другую таблицу, но с другим порядком колонок!
если просто выполнить INSERT INTO table SELECT NEW.* - из-за разницы в порядке колонок всё плохо.

по идее можно обойти проблему если динамически сформировать список колонок также как он идёт в NEW
но с динамическим формированием списка колонок тоже не всё так просто
есть hstore - которому можно скормить тип RECORD но там ломается порядок колонок
есть старое расширение colnames, которое не хотелось бы тянуть в проект
можно тупо сделать запрос в information_schema.columns по таблице на которую сработал триггер и вытянуть порядок колонок в исходной таблице в NEW он будет аналогичным.

ничего лучше не нашёл. может есть нормальный простой вариант?

1 ответов

3 просмотра

полагаться на порядок колонок - антипаттерн. явно пропиши их.

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

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

@Aiwan что такое база образца?
Alexey
27
Не многие знают, а кто знает, тот уже успел забыть, что в далёком 2004 году эта игра произвела настоящий фурор, настолько революционной была технология, применяемая для её соз...
ICCID
4
коллеги, добрый вечер! А никто не знает как модальная форма может себя закрыть? Ну допустим модальная форма определила, что смысла ей работать нет и хочет вернуть modalResult...
Михаил
83
Короче я тут узнал полный пиздец Что кучу постов которые я создавал через posted Спустя время не могу редактировать и менять Мол телега возвращае ошибку Это реально так ...
inc.
13
Хотя у меня сейчас есть более сложная задача, вот её думаю: как объяснить челу переходного возраста противоположного полу, обучающегося в польском колледже (а-ля наш техникум)...
Вячеслав Кузьменко
15
а сколько всего в IT умерло? Где флеш-игры, их было туча, где они все? Сегодня технология есть, а завтра вжух и мёртвая. Этот wasm сильно напоминает джавовские апплеты, silver...
Constantin F.
5
Добрый день Хочу начать обучение языку, не являюсь представителем it, буду благодарна за помощь, совсем пока не понимаю ничего) Подскажите, пожалуйста, где можно начать первы...
Sara Lala
30
а вы в курсе, что Initialize() не работает? var arr123: array[0..123] of Byte; ... Initialize(arr123, SizeOf(arr123));
Iluha Companets
8
что читать по делфи?вообще 0 в нем
fd dsds
9
верно что я могу удалить эти addq и subq т.к. со стеком никакого взаимодействия нет (исключая call)?
Michael
16
Карта сайта