Главная страница
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.013 c
14-1907
MBo
2002-12-06 10:10
2003.01.02
Очередная пятничная задачка ;)


1-1826
ILYA1
2002-12-20 00:16
2003.01.02
FastNet непоректро наботает с аттачментами.


14-1889
----
2002-12-13 13:50
2003.01.02
Из исходника диаграмка (чем и возможно ли)????


14-1866
Anatoly Podgoretsky
2002-12-12 07:47
2003.01.02
Именинники 12 декабря


1-1834
Checist [root]
2002-12-20 10:16
2003.01.02
Ввод по маске