Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2003.09.22;
Скачать: CL | DM;

Вниз

Использование триггеров   Найти похожие ветки 

 
AlexA ©   (2003-08-29 10:19) [0]

Имееться две таблицы. Между ними связь 1-М.
В первой таблице Т1 иметься поле "Количество".
И во второй таблице Т" иметься поле "Количество".
Необходимо отслеживать, условие: Сумма для связанных записей для Т2 не превышала количество для Т1.
Для чего создаю в Т1 поле "Использованое количество" Kolvo_U
и в триггерах для Т2 пытаюсь изменять указаное поле, примерно следующим образом.
Update t1 set Kolvo_U = old.Kolvo_U + :K
Вопрос в следующем: Т.к. тригеры выполняются в рамках транзакции не может ли такое построение привести к неправильной записи в поле Kolvo_U


 
stud ©   (2003-08-29 10:43) [1]

так зачем это отслеживать???
что характеризует "количество" в Т1 и Т2?


 
AlexA ©   (2003-08-29 10:50) [2]

>stud
по предметной области это необходимо. В случае: Sum("количество") в Т2 превысит "количество" в Т1 вызываеться исключение


 
Sergey13 ©   (2003-08-29 10:52) [3]

AlexA © (29.08.03 10:19)
>Вопрос в следующем: Т.к. тригеры выполняются в рамках транзакции не может ли такое построение привести к неправильной записи в поле Kolvo_U
Если правильно работать с транзакциями - не должно.

2stud © (29.08.03 10:43) [1]
Например количество поставки и остаток. Отход от нормализации налицо, но производительность повышает.


 
AlexA ©   (2003-08-29 11:03) [4]

Sergey13 © (29.08.03 10:52) [3]
Поясни как правильно работать с транзакциями?


 
Sergey13 ©   (2003-08-29 11:11) [5]

2AlexA © (29.08.03 11:03) [4]
Начало транзакции
Изменения
IF нормально - COMMIT
else ROLLBACK


 
AlexA ©   (2003-08-29 11:19) [6]

Sergey13 © (29.08.03 11:11) [5]
А как можно по другому :)
Вот я и сомневаюсь не может ли быть ситуации когда для двух транзакций будет состояние "нормально". Например: одна транзакция запись встаила, но еще не потрвердила изменения.


 
Sergey13 ©   (2003-08-29 11:34) [7]

2AlexA © (29.08.03 11:19) [6]
>А как можно по другому :)
Не знаю 8-)

>Вот я и сомневаюсь не может ли быть ситуации когда для двух транзакций будет состояние "нормально". Например: одна транзакция запись встаила, но еще не потрвердила изменения.

Проверяй если сомневаешься. Значение поля Kolvo_U у тебя должно быть равно сумме из Т2. Проверяй периодически, если охота. Один запрос и сомнения либо подтверждаются либо рассеиваются. 8-)


 
AlexA ©   (2003-08-29 11:42) [8]

>Sergey13 © (29.08.03 11:34) [7]
спасибо :-)


 
stud ©   (2003-08-29 12:05) [9]

я так понимаю - ты что-то списываеш и что-то добаляеш?
так поставь триггер на те таблицы которые в которых это фиксируется .
и эти операции проводи в рамках одной транзакции


 
MsGuns ©   (2003-08-29 12:27) [10]

У меня есть один проект, где делается цепочка изменений в около 2 десятков таблиц за раз. Все в одной транзакции. После того, как я увидел как это работает, я расплевался с Парадоксом.


 
Zacho ©   (2003-08-29 13:10) [11]

Да нормально все будет, правда можно напороться на deadlock (на самом деле - обычный lock conflict), но его можно и обработать.



Страницы: 1 вся ветка

Текущий архив: 2003.09.22;
Скачать: CL | DM;

Наверх




Память: 0.49 MB
Время: 0.027 c
1-71679
vladraven
2003-09-11 17:17
2003.09.22
Исходники, ограничивающие срок работы программы.


3-71485
Engel
2003-09-01 19:33
2003.09.22
Компоненты для переноса таблицы


8-71760
LoMik
2003-05-24 21:57
2003.09.22
Изменить уровень громкости


7-71979
Игорь_1984
2003-07-09 11:41
2003.09.22
Как убить процесс, зная его имя?


3-71539
Vitaly
2003-08-29 19:17
2003.09.22
SQL