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

Вниз

Что-то вроде триггера для dbf   Найти похожие ветки 

 
sers   (2002-12-11 13:29) [0]

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

Можно ли в чужой dbf-ке отловить момент вставки новой записи и соответственно updat-ить необходимую запись ?

Если нельзя выцепить запись - можно конечно сделать так:

update table set author=CurrentUser where author=""

Но как поймать момент вставки записи ?


 
Johnmen ©   (2002-12-11 13:58) [1]

> Но как поймать момент вставки записи ?

А кто, по-твоему, должен ловить ? Подумай над этим...


 
sers   (2002-12-11 16:19) [2]

Как кто. Моя прога. Вторая.

Например можно по таймеру отслеживать размер файла и если он увеличился запись вставлена. Хотя записи могут кэшироваться и это дело не пойдет.

Похоже что ничего тут не поделаешь


 
Digitman ©   (2002-12-11 16:37) [3]


> sers


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

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



 
dimis   (2002-12-11 17:12) [4]


> Digitman © (11.12.02 16:37)

c каких это пор в Paradoxе появились транзакции?

> sers
IMHO
вариантов два .
либо переписать программу
либо экспортировать таблички в другую СУБД ,где есть тригеры(например InterBase)
если программа написана нормально, то проблем возникнуть не должно


 
Roki   (2002-12-11 17:23) [5]

dimis прав - переписать прогу самый лучший выход. Разберись со структурой БД и впред!


 
Digitman ©   (2002-12-11 17:30) [6]

>dimis

С каких пор я упоминал при произнесении слова "транзакция" слово "Paradox" ?

Если уж на то пошло, то т/а в в этом случае "эмулируется" объетом BDE.TDatabase на базе *.lck- структур, создаваемых тем же Парадоксом



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

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

Наверх




Память: 0.48 MB
Время: 0.007 c
1-1825
ДмитрийК.
2002-12-20 22:56
2003.01.02
Срочно нужна помощь!!!


4-1934
ctapik-net
2002-11-14 18:39
2003.01.02
WM_QUERYENDSESSION - shutdown or reboot?


3-1765
BorisUK
2002-12-11 15:23
2003.01.02
как в DBGride и StringGride установить фокус ввода на ячейку


14-1915
LongIsland
2002-12-15 12:34
2003.01.02
Чем отличается программист от политика?


14-1918
Виктор Щербаков
2002-12-04 14:55
2003.01.02
Стихи :)