Недавно добавленные исходники

•  DeLiKaTeS Tetris (Тетрис)  4 004

•  TDictionary Custom Sort  6 113

•  Fast Watermark Sources  5 909

•  3D Designer  8 746

•  Sik Screen Capture  6 232

•  Patch Maker  6 664

•  Айболит (remote control)  6 656

•  ListBox Drag & Drop  5 513

•  Доска для игры Реверси  95 608

•  Графические эффекты  6 873

•  Рисование по маске  6 079

•  Перетаскивание изображений  5 049

•  Canvas Drawing  5 414

•  Рисование Луны  5 136

•  Поворот изображения  4 683

•  Рисование стержней  3 296

•  Paint on Shape  2 537

•  Генератор кроссвордов  3 427

•  Головоломка Paletto  2 742

•  Теорема Монжа об окружностях  3 531

•  Пазл Numbrix  2 321

•  Заборы и коммивояжеры  3 009

•  Игра HIP  1 964

•  Игра Go (Го)  1 882

•  Симулятор лифта  2 233

•  Программа укладки плитки  1 947

•  Генератор лабиринта  2 387

•  Проверка числового ввода  2 076

•  HEX View  2 399

•  Физический маятник  2 032

 
скрыть

  Форум  

Delphi FAQ - Часто задаваемые вопросы

| Базы данных | Графика и Игры | Интернет и Сети | Компоненты и Классы | Мультимедиа |
| ОС и Железо | Программа и Интерфейс | Рабочий стол | Синтаксис | Технологии | Файловая система |



Delphi Sources

Как сделать откат внутри триггера



Внутри триггера нельзя управлять транзакциями, поэтому генерируешь там исключение а откат транзакции делаешь в приложении, пославшем запрос. Естественно exception должен предварительно создан


SET TERM !!;

CREATE TRIGGER " DELETE_INV"  FOR " TINV"
    ACTIVE BEFORE DELETE
    POSITION 10
    AS
    BEGIN
        IF (EXISTS (SELECT tOst.Id FROM tOst
                    WHERE tOst.Id = tInv.Id))
        THEN
            EXCEPTION EST_OSTATOK;
    END !!

SET TERM ;!!


DBase.StartTransaction;
try
  Query.ExecSQL;
  DBase.Commit;
except
  DBase.Rollback;
  raise;    // Для последующей обработки
end;





Похожие по теме исходники

Текст внутри файла




Copyright © 2004-2025 "Delphi Sources" by BrokenByte Software. Delphi World FAQ

Группа ВКонтакте