Этот баннер — требование Роскомнадзора для исполнения 152 ФЗ.
«На сайте осуществляется обработка файлов cookie, необходимых для работы сайта, а также для анализа использования сайта и улучшения предоставляемых сервисов с использованием метрической программы Яндекс.Метрика. Продолжая использовать сайт, вы даёте согласие с использованием данных технологий».
Политика конфиденциальности

Новые сообщения [новые:0]
Дайджест
Горячие темы
Избранное [новые:0]
Форумы
Пользователи
Статистика
Статистика нагрузки
Мод. лог
Поиск
|
|
21.05.2007, 00:10
|
|||
|---|---|---|---|
|
|||
BEFORE Insert триггер |
|||
|
#18+
Добрый всем вечер! У меня есть 2 таблицы: Table "ContrAgents" ( caId serial, type int4 ); Table "Hotel" ( hotelId serial, caId int4 ); "Hotel".caId ссылается на "ContrAgents".caId (foreign key). Мне нужно сделать следующее: при добавлении записи в таблицу "Hotel" сначала добавляется запись в таблицу "ContrAgents" (иначе нельзя: целостность нарушается), а затем уже происходит вставка записи в "Hotel". Помогите, пожалуйста, написать триггер для выполнения этих действий. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|
21.05.2007, 18:36
|
|||
|---|---|---|---|
BEFORE Insert триггер |
|||
|
#18+
Может сначала подумать, а нужно ли это? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|
21.05.2007, 19:09
|
|||
|---|---|---|---|
|
|||
BEFORE Insert триггер |
|||
|
#18+
Да нужно, в общем-то. Таблица "ContrAgents" служебная, поэтому хранимая процедура не очень хорошо подходит: пользователь должен выполнять обычный Insert вместо запуска хранимой процедуры. В общем, решение я уже нашел (во многом, методом "тыка") :) Выглядит оно до безобразия просто: Код: plaintext 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|
21.05.2007, 22:21
|
|||
|---|---|---|---|
|
|||
BEFORE Insert триггер |
|||
|
#18+
EtanderДа нужно, в общем-то. Таблица "ContrAgents" служебная, поэтому хранимая процедура не очень хорошо подходит: пользователь должен выполнять обычный Insert вместо запуска хранимой процедуры. В общем, решение я уже нашел (во многом, методом "тыка") :) Выглядит оно до безобразия просто: Код: plaintext 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. выбросите это -- а если при вставке в "Hotel" используется уже существующее значение caId? да, есть ещё RULES: http://developer.postgresql.org/docs/postgres/rule-system.html и DEFERRABLE CONSTRAINTS: http://developer.postgresql.org/docs/postgres/sql-createtable.html также рекомендую узнать, что такое nextval() :) ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|

start [/forum/topic.php?fid=53&tablet=1&tid=2005433]: |
0ms |
get settings: |
8ms |
get forum list: |
17ms |
check forum access: |
4ms |
check topic access: |
4ms |
track hit: |
59ms |
get topic data: |
9ms |
get forum data: |
2ms |
get page messages: |
36ms |
get tp. blocked users: |
1ms |
| others: | 228ms |
| total: | 368ms |

| 0 / 0 |
