• ⚡️ Последний шанс: Вебинар по пентесту стартует через 30 минут!

    Друзья, ровно через 30 минут (8 июля в 19:00) начинается наш практический вебинар по пентесту и поиску уязвимостей!

    Если вы хотите:
    🕵️‍♀️ Узнать, как находить и эксплуатировать уязвимости в веб-приложениях.
    💡 Получить ценные инсайты от настоящего эксперта.
    🚀 Сделать решительный шаг в мир кибербезопасности.
    То этот вебинар для вас!

    Ведущий вебинара – Александр Медведев – эксперт с более чем 10-летним опытом в сфере информационной безопасности, пятикратный победитель Standoff и обладатель престижных сертификаций: OSWE, OSCP, PNPT, CEH, CWAPT.

    Успейте присоединиться! Зарегистрироваться сейчас

    Возникли сложности с регистрацией? Пишите нам: @Codeby_Academy
    Будем вас ждать!

Обработка ошибок в триггере (ms-sql 2000)

  • Автор темы Автор темы *null
  • Дата начала Дата начала
Статус
Закрыто для дальнейших ответов.
N

*null

Здравствуйте!

Суть проблемы:
Требуется поставить триггер на таблицу, чтобы при удалении записи(ей) происходила вставка этой записи в дублирующую таблицу (типа «бэкап»). Проблема в том, что структура таблицы (на которую ставим триггер) может меняться и в этом случае не только не происходит вставка записи, но и вообще не происходит удаление – процедура триггера сразу вываливается.

Вопрос: как можно обеспечить в триггере обработку ошибки (вставка удаляемой записи в другую таблицу, при разных структурах таблиц), чтобы не происходил «вылет» или хотя бы можно было вручную удалить эту запись?
 
<!--QuoteBegin-*null+22:03:2007, 20:40 -->
<span class="vbquote">(*null @ 22:03:2007, 20:40 )</span><!--QuoteEBegin-->как можно обеспечить в триггере обработку ошибки (вставка удаляемой записи в другую таблицу, при разных структурах таблиц)
[snapback]59861" rel="nofollow" target="_blank[/snapback]​
[/quote]
вставлять строку в blob|xml|любое_другое поле.
 
гм... В моем случае, это не лучшее решение, т.к. мне еще необходимо делать выборку из основной таблицы UNION с бэкапной. Если так вставлять - слишком много сложностей будет.

Но вопрос в другом: как в триггере (on delete) можно _проигнорировать_ ошибку при вставки строки в таблицу, чтобы по крайней мере нормально прошло удаление?

И еще сразу вопрос в тему: какой самый простой способ сравнить структуры таблиц? Есть вариант генерить CREATE-скрипты, а потом их сравнивать, или как раз пытаться вставлять запись из одной таблицы в другую. Но может есть способы получше/полегче?
 
Анализируйте системные таблицы на предмет одинаковости данных в них о структуре обеих таблицах .. вариант наверное проще чем генерить скрипты...
 
<!--QuoteBegin-*null+23:03:2007, 10:32 -->
<span class="vbquote">(*null @ 23:03:2007, 10:32 )</span><!--QuoteEBegin-->как в триггере (on delete) можно _проигнорировать_ ошибку при вставки строки в таблицу,
[snapback]59887" rel="nofollow" target="_blank[/snapback]​
[/quote]
что за СУБД?
ага. MS SQL 2000. торможу.
 
Можно воспользоваться системной хранимой функцией sp_columns и получить список полей, а далее дело техники.
Обработку ошибок 2000-й не поддеоживает , 2005-ый - поддерживает.
 
Сейчас делаю проверку структур таблиц перед вставкой записи. вроде работает.
Всем спасибо за ответы!
 
Статус
Закрыто для дальнейших ответов.
Мы в соцсетях:

Взломай свой первый сервер и прокачай скилл — Начни игру на HackerLab

Похожие темы