Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2005.10.16;
Скачать: [xml.tar.bz2];

Вниз

Определить изменилась ли запись в триггере?   Найти похожие ветки 

 
Ярослав   (2005-09-01 07:07) [0]

У меня есть триггер на изменение записи (before update) в нем мне нужно произвести действия если запись была действительно изменена, а если нет то делать ничего не надо.
Как мне определить что запись действительно изменена?
Можно сравнивать все поля на предмет old.field=new.field, но мне нужно производить это действие для нескольких таблиц, а у них набор полей соответственно различен, есть ли способ сделать это как то универсально, т.е. один и тот же код для триггеров различных таблиц?


 
ANB ©   (2005-09-01 09:04) [1]

Вообще то в триггере можно описать поля, при изменении которых он срабатывает. Для разных таблиц триггер работать не будет (не представляю, как это будет выглядеть синтаксически)


 
Sergey_Masloff   (2005-09-01 09:06) [2]

ИМХО нельзя. Код триггера 1) не интерпретируемый 2) Не знает для какой таблицы он вызывается.
 Вообще подобные вещи делаются инструментально CASE средствами (генерится статический код) а не наживается геморрой с динамическим кодом триггера


 
Sergey13 ©   (2005-09-01 09:17) [3]

Если тригер before update сработал, то почему остались сомнения в том, что запись изменена?


 
Zacho ©   (2005-09-01 09:24) [4]

Sergey13 ©   (01.09.05 9:17) [3]

Потому что запись может быть и не изменена :) Напимер, UPDATE MY_TABLE SET MY_FIELD=MY_FIELD


 
Sergey_Masloff   (2005-09-01 09:24) [5]

Sergey13 ©   (01.09.05 09:17) [3]
>Если тригер before update сработал, то почему остались сомнения >в том, что запись изменена?
update sometable set somefield = somefield where id = key


 
Sergey_Masloff   (2005-09-01 09:25) [6]

Zacho ©   (01.09.05 09:24) [4]
;-)


 
Виталий Панасенко   (2005-09-01 10:04) [7]


> Zacho ©   (01.09.05 09:24) [4]
> Sergey13 ©   (01.09.05 9:17) [3]
>
> Потому что запись может быть и не изменена :) Напимер, UPDATE
> MY_TABLE SET MY_FIELD=MY_FIELD

Если все грамотно сделано, то БД останется в том же состоянии
что и до UPDATE (только что-то типа логов может поменятся).. Я так думаю.. А там - ... его знает !..:-))


 
Sergey13 ©   (2005-09-01 10:25) [8]

2[4] Zacho ©   (01.09.05 09:24)
[5] Sergey_Masloff   (01.09.05 09:24)

Синхронно однако. 8-)

Это оч-ч-ч-чень частный случай. И к тому же ИМХО весьма редкий. Я не думаю, что это постоянная практика. Данные остались такими же с логической точки зрения. Физически они изменились.


 
Sergey_Masloff   (2005-09-01 11:27) [9]

Sergey13 ©   (01.09.05 10:25) [8]
>Я не думаю, что это постоянная практика
Извини, ошибаешься. Очень многие инструментальные стредства генерят именно такой код. Всякие Oracle Forms (а на них пишется поболее чем на дельфях, ИМХО). Понимаю что вопрос по интербейсу но с ним ситуация похожая - тулзы часто такой код генерят.
 А человек хочет ловить важные с т.з. бизнес-логики изменения. Если моя зарплата изменилась с N на N это не изменение а если с N на 10*N то имхо для истории нелишне зафиксировать автора изменения.


 
Sergey13 ©   (2005-09-01 11:40) [10]

2 [9] Sergey_Masloff   (01.09.05 11:27)
>Очень многие инструментальные стредства генерят именно такой код.
Может быть. Спорить не буду. Хоть и не думаю, что описанное тобой имеет свойство быть у автора. Хотя - кто знает.

Тогда можно посоветовать автору, попробовать ловить одинаковость на другом конце - там где он что-то делает или не делает по событию. Может там можно придумать универсальное решение. Хотя сомневаюсь я в этом. Универсальность тут может достигаться только использованием чтения метаданных и динамического СКЛ на их основе (другого пути я не вижу). А это не есть гуд в тригерах. ИМХО. Проще все old.field=new.field перебрать.


 
Sergey_Masloff   (2005-09-01 12:23) [11]

Sergey13 ©   (01.09.05 11:40) [10]
>Универсальность тут может достигаться только использованием >чтения метаданных и динамического СКЛ на их основе (другого >пути я не вижу). А это не есть гуд в тригерах. ИМХО. Проще все >old.field=new.field перебрать
Это 100%. Тем более написать в ERWIN скрипт который сгенерирует этот перебор в триггере - задача элементарная.


 
Игорь Шевченко ©   (2005-09-01 18:41) [12]


> А человек хочет ловить важные с т.з. бизнес-логики изменения.
> Если моя зарплата изменилась с N на N это не изменение а
> если с N на 10*N то имхо для истории нелишне зафиксировать
> автора изменения.


А для истории не хреново бы фиксировать все изменения такого рода, вне зависимости от значения. Это так, к слову.


 
Ярослав   (2005-09-02 06:38) [13]

>> Игорь Шевченко ©   (01.09.05 18:41) [12]
>> А для истории не хреново бы фиксировать все изменения такого рода, вне зависимости от значения. Это так, к слову.

???
Даже тех которых не было???
Пользователь открывает форму, ничего не делает на ней и жмет "Сохранить" Естественно запись примет теже самые значения т.е. не будет изменена, а триггер сработает и запишет в историю тоже самое? Я хочу чтобы такого небыло. На клиенте отслежывать изменил чтото пользователь или нет, я считаю несколько не правильно.


 
Sergey13 ©   (2005-09-02 09:18) [14]

2 [13] Ярослав   (02.09.05 06:38)
А нафига сохранять что либо, если ничего не сделано?

>Я хочу чтобы такого небыло.
Никто тебя и не побуждает делать так. 8-)

>На клиенте отслежывать изменил чтото пользователь или нет, я считаю несколько не правильно.
Религия что-ли? Почему клиент не может следить за собой?


 
Виталий Панасенко   (2005-09-02 10:11) [15]


> Пользователь открывает форму, ничего не делает на ней и
> жмет "Сохранить"

Если используешь DBControls, то по нажатию "Сохранить" ничего и не будет сохранено (если, конечно, в обработчике ничего загадочного не делать, кроме Post) т.к. НД будет в сосотоянии dsBrowse


 
ККВ   (2005-09-02 10:43) [16]

Попробывать применить условие:
if old.value<>new value then
что-то делать


 
Digitman ©   (2005-09-02 11:56) [17]


> На клиенте отслежывать изменил чтото пользователь или нет,
> я считаю несколько не правильно


правильно или неправильно, но в твоей ситуации у тебя выбора нет - либо ты лепишь триггеры для каждой таблицы (что скорей всего в любом случае рано или поздно понадобится) либо прежде чем постить проводишь анализ изменений на кл.стороне


 
Андрей Жук ©   (2005-09-02 12:22) [18]


> правильно или неправильно, но в твоей ситуации у тебя
> выбора нет - либо ты лепишь триггеры для каждой
> таблицы (что скорей всего в любом случае рано или
> поздно понадобится) либо прежде чем постить проводишь
> анализ изменений на кл.стороне

А почему либо-либо? Лучше делать и. А вдруг потом придумаешь сделать еще и морду на php?


 
Alexander Panov ©   (2005-09-02 12:59) [19]

А разве нельзя воспользоваться событиями TDataset?


 
Игорь Шевченко ©   (2005-09-02 16:39) [20]


> ???
> Даже тех которых не было???
> Пользователь открывает форму, ничего не делает на ней и
> жмет "Сохранить" Естественно запись примет теже самые значения
> т.е. не будет изменена, а триггер сработает и запишет в
> историю тоже самое? Я хочу чтобы такого небыло. На клиенте
> отслежывать изменил чтото пользователь или нет, я считаю
> несколько не правильно.


А нафига по сети гонять то, что не менялось ?



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

Форум: "Базы";
Текущий архив: 2005.10.16;
Скачать: [xml.tar.bz2];

Наверх




Память: 0.5 MB
Время: 0.04 c
14-1127713782
boriskb
2005-09-26 09:49
2005.10.16
В какой стране вам хотелось бы пожить?


14-1127220284
Дядя Фёдор
2005-09-20 16:44
2005.10.16
Как сделать чтоб при надатии кнопки содержимое Edit сохранялась в


2-1127251509
ArtemESC
2005-09-21 01:25
2005.10.16
Delphi|Tools|Editor Options| Source opti...|Source file type


2-1124471103
NikNet
2005-08-19 21:05
2005.10.16
Как перевести MP3/WAV/WMA/... в MIDI? на DELPHI?


3-1125663128
jeka_t
2005-09-02 16:12
2005.10.16
Как обновить данные в таблице компонента TADOQuery?





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский