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

Тема в разделе "SQL", создана пользователем *null, 22 мар 2007.

Статус темы:
Закрыта.
  1. *null

    *null Гость

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

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

    Вопрос: как можно обеспечить в триггере обработку ошибки (вставка удаляемой записи в другую таблицу, при разных структурах таблиц), чтобы не происходил «вылет» или хотя бы можно было вручную удалить эту запись?
     
  2. ????

    ???? Гость

    <!--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|любое_другое поле.
     
  3. *null

    *null Гость

    гм... В моем случае, это не лучшее решение, т.к. мне еще необходимо делать выборку из основной таблицы UNION с бэкапной. Если так вставлять - слишком много сложностей будет.

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

    И еще сразу вопрос в тему: какой самый простой способ сравнить структуры таблиц? Есть вариант генерить CREATE-скрипты, а потом их сравнивать, или как раз пытаться вставлять запись из одной таблицы в другую. Но может есть способы получше/полегче?
     
  4. Barmutik

    Barmutik Гость

    Анализируйте системные таблицы на предмет одинаковости данных в них о структуре обеих таблицах .. вариант наверное проще чем генерить скрипты...
     
  5. ????

    ???? Гость

    <!--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. торможу.
     
  6. DZX

    DZX Гость

    Можно воспользоваться системной хранимой функцией sp_columns и получить список полей, а далее дело техники.
    Обработку ошибок 2000-й не поддеоживает , 2005-ый - поддерживает.
     
  7. *null

    *null Гость

    Сейчас делаю проверку структур таблиц перед вставкой записи. вроде работает.
    Всем спасибо за ответы!
     
Загрузка...
Похожие Темы - Обработка ошибок триггере
  1. kolka
    Ответов:
    6
    Просмотров:
    254
  2. vladis222
    Ответов:
    1
    Просмотров:
    1.303
  3. Akupaka
    Ответов:
    64
    Просмотров:
    18.108
  4. sanch
    Ответов:
    2
    Просмотров:
    2.712
  5. anna
    Ответов:
    9
    Просмотров:
    885
Статус темы:
Закрыта.

Поделиться этой страницей